博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql logs-slave-updates (A -> B -> C)
阅读量:2183 次
发布时间:2019-05-02

本文共 1948 字,大约阅读时间需要 6 分钟。

--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

转载地址:http://csokb.baihongyu.com/

你可能感兴趣的文章
CART 分类与回归树
查看>>
seq2seq 的 keras 实现
查看>>
seq2seq 入门
查看>>
什么是 Dropout
查看>>
用 LSTM 做时间序列预测的一个小例子
查看>>
用 LSTM 来做一个分类小问题
查看>>
详解 LSTM
查看>>
按时间轴简述九大卷积神经网络
查看>>
详解循环神经网络(Recurrent Neural Network)
查看>>
为什么要用交叉验证
查看>>
用学习曲线 learning curve 来判别过拟合问题
查看>>
用验证曲线 validation curve 选择超参数
查看>>
用 Grid Search 对 SVM 进行调参
查看>>
用 Pipeline 将训练集参数重复应用到测试集
查看>>
PCA 的数学原理和可视化效果
查看>>
机器学习中常用评估指标汇总
查看>>
什么是 ROC AUC
查看>>
Bagging 简述
查看>>
详解 Stacking 的 python 实现
查看>>
简述极大似然估计
查看>>