设为首页 收藏本站
查看: 503|回复: 0

[经验分享] mysql: logs-slave-updates备忘

[复制链接]

尚未签到

发表于 2016-9-13 06:59:49 | 显示全部楼层 |阅读模式
  --logs-slave-updates
  通常情况,从服务器从主服务器接收到的更新不记入它的二进制日志。该选项告诉从服务器将其SQL线程执行的更新记入到从服务器自己的二进制日志。为了使该选项生效,还必须用--logs-bin选项启动从服务器以启用二进制日志。如果想要应用链式复制服务器,应使用--logs-slave-updates。例如,可能你想要这样设置:
  A -> B -> C
  也就是说,A为从服务器B的主服务器,B为从服务器C的主服务器。为了能工作,B必须既为主服务器又为从服务器。你必须用--logs-bin启动A和B以启用二进制日志,并且用--logs-slave-updates选项启动B。

以上是摘自mysql对于logs-slave-updates启动选项的描述。
当然logs-slave-upates也可以写入my.cnf :
//////////////////
log_slave_updates=1
//////////////////
  当然在这种机制下可能有的同学会存在这么个问题:
如果a->b   b->a   这样的双master架构下,a,b都打开log_slave_updates选项会不会出现无限循环的状态。
mysql已经考滤到了这个问题,每条bin-log都会记录执行语句的源server_id.当slave读到语句的server_id等于本身的ID的时候,不会忽略执行,所以我们不用担心a,b会不会无限循环下去。
  基于以上这种情况,mysql的replication集群将更加灵活,你如果需要可以做成各种各样的链式复制。比如 a->b   b->a     b中设置log_slave_updates后还可以b->c.   这样a,c中的数据也是一致的。   
  测试部分my.cnf

26 [mysqld2]
27 pid-file        = /home/shanfeng/mysql/data2/mysqld2.pid
28 socket          = /home/shanfeng/mysql/data2/mysqld2.sock
29 port            = 3307
30 datadir         = /home/shanfeng/mysql/data2
31 log             = /home/shanfeng/mysql/log2/log.log
32 log_bin             = /home/shanfeng/mysql/log2/mysql_bin.log
33
34 server_id = 2
35
36
37 master-host     = 127.0.0.1
38 master-user     = testuser
39 master-password = testpas
40 master-port     = 3308
41
42
43 [mysqld3]
44 pid-file        = /home/shanfeng/mysql/data3/mysqld3.pid
45 socket          = /home/shanfeng/mysql/data3/mysqld3.sock
46 port            = 3308
47 datadir         = /home/shanfeng/mysql/data3
48 log             = /home/shanfeng/mysql/log3/log.log
49 log_bin             = /home/shanfeng/mysql/log3/mysql_bin.log
50
51 log_slave_updates = 1
52
53 server_id = 3
54
55 master-host     = 127.0.0.1
56 master-user     = testuser
57 master-password = testpas
58 master-port     = 3307
  
   60 [mysqld4]
61 pid-file        = /home/shanfeng/mysql/data4/mysqld4.pid
62 socket          = /home/shanfeng/mysql/data4/mysqld4.sock
63 port            = 3309
64 datadir         = /home/shanfeng/mysql/data4
65 log             = /home/shanfeng/mysql/log4/log.log
66 log_bin             = /home/shanfeng/mysql/log4/mysql_bin.log
67
68 server_id = 4
69
70 master-host     = 127.0.0.1
71 master-user     = testuser
72 master-password = testpas
73 master-port     = 3308

  以上实例是 server2与server3双master备份。server4是两server的slave

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-271363-1-1.html 上篇帖子: [转]MySQL 用户权限分配 下篇帖子: mysql数据库主从同步
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表