Skip to content


mysql: logs-slave-updates备忘


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

Posted in jQuery, linux, mysql, php, tools, 技术.

Tagged with , , .


One Response

Stay in touch with the conversation, subscribe to the RSS feed for comments on this post.

  1. Gonten says

    看来又是一个Linux高手



Some HTML is OK

or, reply to this post via trackback.