`

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

分享到:
评论

相关推荐

    unity插件:Unity-Logs-Viewer

    Unity - Logs - Viewer 是一个专门用于查看和分析 Unity 项目日志的工具。在 Unity 开发过程中,会产生大量的日志信息,这些日志包含了诸如脚本中的调试信息、警告信息和错误信息等。该工具可以帮助开发者更高效地...

    Unity-Logs-Viewer-master.rar

    Unity-Logs-Viewer-master 是一个专门为Unity游戏开发者设计的工具,旨在简化真机调试过程,尤其是在iOS和Android设备上。这个工具允许开发者在游戏运行时实时查看Debug日志,极大地提高了开发效率和问题排查能力。 ...

    深入java虚拟机光盘源码-jvm-gc-logs-analyzer:jvm-gc-logs-analyzer

    深入java虚拟机光盘资源jvm-gc-logs-analyzer 这个项目是一个 Java 虚拟机和垃圾收集器日志分析器。 它专用于 JVM 11 及更高版本(JVM 8 支持正在开发中)。 日志必须采用适当的格式和适当的装饰器,检查最后部分的...

    Unity-Logs-Viewer-master.zip

    Unity-Logs-Viewer-master.zip 是一个专门为Unity开发者设计的压缩包,其中包含了一个插件,用于在不依赖ADB(Android Debug Bridge)的情况下查看Unity在真机设备上的运行日志。这个插件对于开发者来说非常实用,...

    Mysql-master-slave.rar_Master/Slave_slave mysql

    MySQL的主从复制是数据库高可用性和数据冗余的一种常见实现方式,它允许数据从一个服务器(主服务器)同步到一个或多个其他服务器(从服务器)。这种架构在处理大量读取操作、提供故障切换能力以及分布式系统中尤其...

    Unity日志输出 Unity-Logs-Viewer

    Unity日志输出插件,在手机和pc上均有用,能很清晰的看到日志打印,非常好用。 使用这个工具,你可以很容易地在游戏内部检查你的编辑器控制台日志!在移动端同样有效! 支持unity2017.4.29 or 更高版本

    启动oracle数据库报错:ORA-00600

    - 在整个过程中,应密切检查数据库的日志文件(redo logs, alert logs, trace files),以获取更多关于错误的线索。这些日志可能会提供导致ORA-00600错误的具体操作或事件。 5. **数据文件和控制文件的检查**: -...

    Python库 | aws-cdk.aws-logs-destinations-1.132.0.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:aws-cdk.aws-logs-destinations-1.132.0.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    PyPI 官网下载 | aws-cdk.aws-logs-destinations-1.49.0.tar.gz

    标题中的"PyPI 官网下载 | aws-cdk.aws-logs-destinations-1.49.0.tar.gz"指的是Python Package Index(PyPI)上发布的名为`aws-cdk.aws-logs-destinations`的软件包,版本为1.49.0,它被压缩成一个`.tar.gz`文件供...

    Python库 | aws-cdk.aws-logs-1.21.1.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:aws-cdk.aws-logs-1.21.1.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    Python库 | napalm-logs-0.0.1b3.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:napalm-logs-0.0.1b3.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    Laravel开发-laravel-logs-rotate

    `laravel-logs-rotate` 是一个针对Laravel的特性,它涉及到如何管理和处理日志文件的滚动与压缩,以保持日志数据的有序性和存储效率。下面将详细阐述这个主题。 ### 1. 日志系统 Laravel内置了一个强大的日志系统...

    运维面试题(含答案).pdf

    - 3306:mysql 病毒解决 1. Linux系统中病毒如何解决? - 找到病毒文件然后删除 - 中毒以后一样机械cpu、内存利用率会比较高,机械向外发包等异样情形,排查方式: - Linux效劳器流量剧增,使用iftop查看有连接...

    Windows下的Tomcat安装压缩包:apache-tomcat-7.0.78.zip

    解压后,你会看到`bin`、`conf`、`lib`、`webapps`、`logs`、`temp`和`work`等目录,它们各自有特定的用途。 3. **环境变量配置**: - **JAVA_HOME**:确保你的系统已经安装了Java JDK,并设置了JAVA_HOME环境变量...

    Python库 | aws-cdk.aws-logs-destinations-1.87.0.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:aws-cdk.aws-logs-destinations-1.87.0.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    alpine-nginx.tar.gz

    4.docker容器内目录/usr/local/nginx/{conf,logs,html},根据需要挂载 构建过程参考博客:...

    docker拉取mysql5.6镜像并run一个容器,使用mysql服务

    docker run -p 3306:3306 --name mysql -v /media/mysql/conf:/etc/mysql/conf.d -v /media/mysql/logs:/logs -v /media/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6 ``` 这将创建一个名...

    logrotate-container:一个logrotate容器映像,用于使用Alpine Linux轮流Kubernetes内部的应用程序的持久日志

    PVC称为app-logs-pv 。 Kubernetes先决条件 示例PVC app-logs-pv必须存在,并且旧版应用会将其日志文件写入该文件。 此PVC的accessMode必须为RWX (ReadWriteMany),因为我们希望将它们从另一个Pod(与应用程序...

    PyPI 官网下载 | aws-cdk.aws-logs-destinations-1.137.0.tar.gz

    标题中的“PyPI 官网下载 | aws-cdk.aws-logs-destinations-1.137.0.tar.gz”表明这是一个从Python Package Index (PyPI) 下载的软件包,名为“aws-cdk.aws-logs-destinations”,版本号为1.137.0,格式为tar.gz。...

Global site tag (gtag.js) - Google Analytics