南京网站制作的价格vis设计机构

web/2025/9/27 11:30:02/文章来源:
南京网站制作的价格,vis设计机构,南城微网站建设,广州思盾互动网站建设公司MySQL Replication 大家都非常熟悉了#xff0c;我也不会写怎么搭建以及复制的原理#xff0c;网上相关文章非常多#xff0c;大家可以自己去搜寻。我在这里就是想总结一下mysql主从复制需要注意的地方。有人说主从复制很简单嘛#xff0c;就是master#xff0c;slave的se…MySQL Replication 大家都非常熟悉了我也不会写怎么搭建以及复制的原理网上相关文章非常多大家可以自己去搜寻。我在这里就是想总结一下mysql主从复制需要注意的地方。有人说主从复制很简单嘛就是masterslave的server_id不一样就搞定。确实简单的来说就是这么简单。但是真正在生产环境我们需要注意的太多了。首先说说主库宕机或者从库宕机后复制中断的问题。虽然很多知识点或许我博客其他文章中都有提到过或者重复了但是我还是想总结一下。主库意外宕机如果没有设置主库的sync_binlog选项就可能在奔溃前没有将最后的几个二进制日志事件刷新到磁盘中。备库I/O线程因此也可一直处于读不到尚未写入磁盘的事件的状态中。当主库从新启动时备库将重连到主库并再次尝试去读该事件但主库会告诉备库没有这个二进制日志偏移量。解决这个问题的方法是指定备库从下一个二进制日志的开头读日志。但是一些事件将永久丢失。可以使用前面文章提到的工具来检查主从数据一致以及修复pt-table-checksum。即使开启了sync_binlogmyisam表的数据仍然可能在奔溃的时候损坏。对于innodb表如果innodb_flush_log_at_trx_commit没有设置为1也可能丢失数据但是数据不会损坏。因此主库的参数建议开启sync_binlog1innodb-flush-log-at-trx-commit1MySQL 5.6版本之前存在一个bug即当启用上述两个参数时会使得InnoDB存储引擎的group commit失效从而导致在写密集的环境中性能的急剧下降。group commit是什么这是一个知识点那为什么sync_binlog1,innodb-flush-log-at-trx-commit1会导致组提交失败这又是一个知识点大家可以查阅相关资料。因此我们常常在性能和数据一致性中做了妥协通常将参数innodb-flush-log-at-trx-commit设置为2而这就导致了master不再是crash safe的主从数据可能会不一致。关于innodb_flush_log_at_trx_commit的有效值为0,1,2。我这里简单提一下因为很多知识点是有连贯性的往往提到这个问题而又涉及到另外的问题^_^0代表当提交事务时并不将事务的重做日志写入磁盘上的日志文件而是等待主线程每秒的刷新。当宕机时丢失1秒的事务。1和2有点相同但是不同的地方在于1表示在执行commit时将重做日志缓冲同步写到磁盘即伴有fsync的调用。2表示将重做日志异步写到磁盘即写到文件系统的缓存中。由操作系统控制刷新。因此不能完全保证在执行commit时肯定会写入重做日志文件只是有这个动作的发生。因此为了保证事务的ACID中的持久性必须将innodb_flush_log_at_trx_commit设置为1也就是每当有事务提交时就必须确保事务都已经写入重做日志文件。那么当数据库因为意外发生宕机时可以通过重做日志文件恢复并保证可以恢复已经提交的事务。而将该参数设置为0或者2都有可能发生恢复时部分事务的丢失。不同之处在于设置为2时当mysql数据库发生宕机而操作系统及服务器并没有发生宕机时由于此时未写入磁盘的事务日志保存在文件系统缓存中当恢复时同样能保证数据不丢失。对于性能与安全我们都要的情况下我们肯定会使用RAID并且开启Write Back功能而且RAID卡提供电池备份单元(BBU,Battery Backup Unit)关于这块的知识童鞋们可以自行查阅相关资料。备库意外宕机当备库在一次非计划的关闭后重启时会去读master.info文件以找到上次停止复制的位置。不幸的是该文件可能并没有同步写到磁盘因为该信息是在缓存中可能并没有刷新到磁盘文件master.info。文件中存储的信息可能是错误的备库可能会尝试重新执行一些二进制日志事件这可能导致主键冲突就是我们常常看见的1062错误。除非能确定备库在哪里停止(很难)否则唯一的办法就是忽略那些错误。在从库导致复制中断有两方面的原因即replication中的SQL thread和IO thread。首先来看SQL thread其主要完成两个操作1.运行relay log中对应的事务信息2.更新relay-info.log文件更新relay-info.log文件是为了记录已经执行relay log中的位置当slave重启后可以根据这个位置继续同步relay log。但是这里用户会发现这两个操作不是在一个事务中一个是数据库操作一个是文件操作因此不能达到原子的效果。此外MySQL数据库默认对于文件relay-info.log是写入到操作系统缓存因此在发生宕机时可能导致大量的已更新位置的丢失从而导致重复执行SQL语句最终的现象就是主从数据不一致。MySQL 5.5新增了参数sync_relay_log_info,可以控制每次事务更新relay-info.log后就进行一次fdatasync操作这加重了系统负担而且即使这样也可能存在最后一个事务丢失的情况。IO thread用于同步master上的二进制日志但是其在crash时依然会导致数据不一致的情况发生。IO thread将收到的二进制日志写入到relay log每个二进制日志由多个log event组成所以每接受到一个log event就需要更新master-info.log。和relay-info.log一样其也是写入操作系统缓存参数sync_master_info可以控制fdatasync的时间。由于IO thread的更新不能像SQL thread一样进行放到一个事务进行原子操作因此其是对数据一致性会产生影响设想一个log event传送到了relay log中两次的情形。不过好在从MySQL 5.5版本开始提供了参数relay_log_recovery当发生crash导致重连master时其不根据master-info.log的信息进行重连而是根据relay-info中执行到master的位置信息重新开始拉master上的日志数据(不过需要确保日志依然存在于master上否则就。。。)somysql 5.5版本的从库推荐配置参数sync_master_info 1sync_relay_log 1sync_relay_log_info 1read_only #从库只读但是有super权限的依然可以写入relay_log_recovery 1skip_slave_start # 默认启动从库就开启了同步io线程和sql线程都运行了该参数是需要手动执行start slave方可启动同步复制过滤选项常常看见很多同学在主库进行过滤选项设置当然这也有好处减少了带宽但是在主库设置过滤选项是非常危险的操作因为无论是显示要过滤的或者要同步的二进制日志只记录你设置的其他的是不会记录的。当主库有数据需要用到binlog恢复时你就准备哭吧。所以通常在备库进行过滤选项设置。比如忽略某个库同步所有库或者同步某一个库当然这会浪费带宽但是和安全比起来这点浪费不算什么。有时候安全与性能往往需要我们自己平衡。还有就是跨库更新如果我们在备库是这样设置的比如同步yayun这个库replicate_do_dbyayun主库记录如下mysql select * fromt1;-----------| id | name |-----------| 1 | yayun || 2 | atlas || 3 | mysql |-----------3 rows in set (0.00sec)mysql备库记录如下mysql select * fromt1;-----------| id | name |-----------| 1 | yayun || 2 | atlas || 3 | mysql |-----------3 rows in set (0.00sec)mysql现在我们在主库插入一条记录mysql usetest;Readingtable information for completion of table and columnnamesYou can turnoff this feature to get a quicker startup with -ADatabasechangedmysql insert into yayun.t1 (name) values (good yayun);Query OK,1 row affected (0.01sec)mysql select * fromyayun.t1;----------------| id | name |----------------| 1 | yayun || 2 | atlas || 3 | mysql || 5 | good yayun |----------------4 rows in set (0.00sec)mysql查看备库mysql select * fromt1;-----------| id | name |-----------| 1 | yayun || 2 | atlas || 3 | mysql |-----------3 rows in set (0.00sec)mysql怎么回事怎么没有同步这就是跨库更新带来的问题比如下面的更新usetestinsert into yayun.t1 (name) values (good yayun)当然你会说哪个2B会这么干啊呵呵有时2B还是有的。所以我们还有另外2个过滤复制参数replicate_wild_do_tablereplicate_wild_ignore_table一个是要同步的表一个是不同步的表通常我们可以这样写replicate_wild_do_tableyayun.%表示同步yayun库下面的所有表这样就解决的跨库更新的问题。复制格式的问题通常推荐使用ROW格式为什么使用看看我前面文章MySQL数据恢复和复制对InnoDB锁机制的影响不要用Seconds_Behind_Master来衡量MySQL主备的延迟时间这个后续我会写相关文章解释为什么不要用该参数衡量主备的延迟时间。总结上面所提到的参数都是最大限度保证主从数据一致以及主库宕机从库宕机复制不会中断但是性能会打折扣所以需要我们自己去衡量或者做妥协。还有很多很多的问题我也只总结了这么一点要是还有大神知道更详细的欢迎一起交流共同进步。^_^参考资料

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/82737.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站开发与设计课程时间上海中国国际进口博览会

不锈钢水槽如何安装?3个细节要注意,不能忽视,别被套路了随着时代不断的进步。人们生活水平也是不断的提高。生活用品有时间来选,慢慢的步入了我们的日常中。你们觉得家中最重要的地方是什么呢?其实就是厨房&#xff0c…

网站建站报价单wordpress自定义文章排列顺序

初学Linux,还在摸索中,在这个过程中希望能记录下学习到的东西,参考的的书籍为《鸟哥的Linux私房菜》 在这里学到的主要命令有这几个: data cal bc man shutdown sync 1、基础命令操作 data----显示日期与实践的命令 cal----显示日…

做婚恋网站赚钱吗手工制作大全简单漂亮

IOC 与 DI IOC(Inversion of Control)控制反转:所谓控制反转,就是把原先我们代码里面需要实现的对象创建、依赖的代码,反转给容器来帮忙实现。那么必然的我们需要创建一个容器,同时需要一种描述来让容器知道需要创建的对象与对象…

最好的网站建设团队虚拟主机+wordpress

1.简介 在第一个教程中,我们创建了一个基本的OpenMap GIS应用程序,该应用程序在JFrame中显示一个从文件系统加载的具有一个形状图层的地图。 该教程基于com.bbn.openmap.app.example.SimpleMap 。 在该教程中,我们使用了以下OpenMap类&#x…

大型公司网站建设采集软件

0 abstract 本文介绍了一项对GitHub Copilot(一种人工智能编程助手)的控制实验结果。研究人员招募了软件开发人员,要求他们尽可能快地用JavaScript实现一个HTTP服务器。实验组可以访问人工智能编程助手,比对照组完成任务的速度快…

大岭山仿做网站基金网站开发

随机创建了长度为十的数组 获得十以类的随机整数 快速获取数组2乘3维的数组 生成20个1到10之间的数组 通过reshape 将这些数变成二位数组 shape这个方法可以查看数组中的元素是几行几列的 转载于:https://www.cnblogs.com/chenligeng/p/9315339.html

主流的网站开发语言电子商务服务平台

2007-10-09我的帐号锁定了,我已经把那个解锁的资料用邮件发去去了,怎么不回呀,不是说24小时吗尊敬的客户:您好!5173客户服务010很高兴为您服务!请您查看下您的邮件是否已经成功提交,您的信息有没有填写齐全…

房产类网站建设费用广东住房和城乡建设部网站

目录 1_computed计算属性使用1.1_复杂data的处理方式1.2_计算属性computed1.3_计算属性 vs methods1.4_计算属性的setter和getter(了解) 2_侦听器watch2.1_认识2.2_侦听器watch的配置选项 1_computed计算属性使用 1.1_复杂data的处理方式 在模板中可以…

建设一个官方网站的费用网站制作谁家好

【0】README 0.1)本文旨在阐述 个人的debug经历,遇到的各种debug 奇葩问题, 说是奇葩,其实也是自己 不小心或者说是编程习惯不好; 【1】debug和running的运行结果不一致(乍眼一看,你肯定醉了&a…

专业网站设计制作服务建站节

1.1.1.1: SDK表单概要说明:我们把流程引擎与表单引擎统称为ccbpm,但是有一些用户并不想使用表单引擎,而是用自己的表单,仅仅使用流程引擎,这样的方式就要采用ccbpm的sdk表单开发模式。关于ccbpm的SDK:ccbpm的sdk就是cc…

旅游交友的网站建设cn的wordpress包

简介本框架旨在为EF Core提供Sharding(即读写分离分库分表)支持,不仅提供了一套强大的普通数据操作接口,并且降低了分表难度,支持按时间自动分表扩容,提供的操作接口简洁统一.源码地址:EFCore.SHarding引言读写分离分库分表一直是数据库领域中的重难点,当数据规模达到单库极限的…

素材网站无水印从域名到网站

2. 3物理层设备 文章目录2. 3物理层设备中继器2.集线器(多口中继器)中继器 2.集线器(多口中继器)

新网域名网站ppt代写平台

1、 mysql安装完成后需要将mysql里面的bin目录加到环境变量里之后,才能在cmd窗口里使用mysql命令 2、 在CMD命令窗口敲入命令 mysql -hlocalhost -uroot -ppassword进入mysql数据库 这里我的用户名是root,密码是123456 转载于:https://www.cnblogs.com/y…

网站建设合作合同模板下载招生型网站建设

《Django 5 By Example》学习第12天,p339-p358总结,总计20页。 一、技术总结 1.项目(购物网站) django-admin startproject myshop 虽然这里只是示例,但我觉得这种命名为 myxxx 的习惯非常不好,因为在实际应用中,是…

免费做网站网站中文网站建设模板下载

问题描述 我目前的环境是: 编辑器: Microsoft Visual Studio Community 2022 (64 位) 运行的脚本是ffmpeg自带的remux样例,只不过我想用c语言执行这个样例。在执行的过程中报错如下图: C4576 后跟初始值设定项列表的带圆括…

设计研发网站网站文案标准格式

作者 | 曾响铃 文 | 响铃说 先讲一个故事。 一个朋友曾经做了一个本地互联网装修平台,一边是装修服务的提供者——各工种工人等,一边是有装修需求的业主。这个平台要做独立生态,绕过旧有的装修公司渠道垄断,直接提供服务&#…

网站代码优化所有标签网站友情链接怎么做

YARN集群模式 本文内容需要基于 Hadoop 集群搭建完成的基础上来实现 如果没有搭建&#xff0c;请先按上一篇: <Linux 系统 CentOS7 上搭建 Hadoop HDFS集群详细步骤> 搭建&#xff1a;https://mp.weixin.qq.com/s/zPYsUexHKsdFax2XeyRdnA 配置hadoop安装目录下的 etc…

阿里巴巴网站优化怎么做html5个人主页

文章目录 传统图像处理颜色空间高斯滤波腐蚀和膨胀开运算和闭运算如何求一张图片的均值?线性插值双线性插值仿射变换透视变换常见的边缘检测算子Sobel 算法Canny 算法Hough 变换原理(直线和圆检测)找轮廓(findCountours)单应性(homography)原理

工业和信息化网站备案系统主机托管

算法释义&#xff1a;计数排序是一种非基于比较的排序算法&#xff0c;它不依赖于比较操作来确定元素的顺序&#xff0c;而是通过键值索引直接确定元素的输出位置。计数排序适用于一定范围内的整数排序。为什么说是一定范围之内呢&#xff1f;原因如下&#xff1a;计数排序的复…

重庆网站制作济南宝安网站(建设深圳信科)

from: 链接&#xff1a;https://www.zhihu.com/question/21142149/answer/109854408 Java是世界上最强大的编程语言之一&#xff0c;很多开发人员和大型企业都偏爱Java&#xff0c;并且在各种应用场景中使用它。在本文中&#xff0c;我们为大家介绍几种Java库来帮助开发人员解决…