我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql如何实现多主双向和级联复制

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql如何实现多主双向和级联复制

这篇文章主要为大家展示了“mysql如何实现多主双向和级联复制”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql如何实现多主双向和级联复制”这篇文章吧。

一.解读

在离线状态的切换,对于web服务来说没什么影响,毕竟代码是一样的,所以不管部署在哪都一样。区别就是数据库中的数据。这就要求我们的主库,以及每个本机PC上部署的从库,他们之间能实现数据的自主同步。

关于可能的冲突,我们已经在业务层规避掉了。不同的单位,不会update相同的字段。不同的单位,不会在相同的表中insert。所以现在就只用关心mysql的自动同步,以及离线重连的自动续传了。

二.web设计

web后端,我设置了读写分离(只是为了装一下,其实大可不必,毕竟内网并发量不高)
2.在线时,单位的访问,均select本地mysql,update/insert/delete总服务器mysql
3.离线时,单位的访问,均在本地mysql
(这很好实现,不同的域名地址,对应不同的项目,项目内提前设定好数据库router,由用户自主决定访问哪个域名地址即可。实际上,如果断网了,总服务器访问不通,他会自然而然的去访问本机服务的域名地址)

三.mysql设计

同步方式毋庸置疑用的是mysql自带的binlog,mysql版本要选择5.7及以上的版本
2.多主双向:每个本机PC上的mysql,要与总服务器上的mysql保持双主同步。
3.总服务器要开启级联复制,将下级单位PC产生的binlog,同步给其他单位的PC。以便其他单位的PC在离线时可以使用这部分数据

四、实操

1.mysql架构图(草稿)

mysql如何实现多主双向和级联复制

2.配置

一阶段,先把所有库的master功能启动,同时在库中创建访问账号供其他库使用:
主主库(总服务器)
①在mysql安装路径下找到启动文件my.inimy.cnf,将如下信息放在启动文件的[mysqld]下:

log_bin=mysql-binbinlog_format=MIXEDsync_binlog=1expire_logs_days=7binlog-do-db=equip_systemslave-skip-errors=allmaster_info_repository=tablerelay_log_info_repository=tablelog-slave-updates=1

各参数的释义:

log_bin=mysql-bin:配置为mysql-bin时,mysql开启binlog功能
binlog_format=MIXED:binlog的记录方式,MIXED为混合记录方式
sync_binlog=1:

触发binlog由缓存刷新到磁盘所需要提交的事务数量,默认为0表示由磁盘文件系统控制,为1表示每提交一个事务即刷新一次(此时最安全,服务异常时丢失的事务最多只有1个,但IO消耗最大,高并发下忌用),常见的DBA一般设置为100。本项目并发量低,可设置为1
expire_logs_days=7:binlog有效时长,设置为7表示binlog存在7天后删除
binlog-do-db=equip_system:要同步的数据库名
slave-skip-errors=all:表示同步出现异常时要跳过哪些异常,设置为all表示所有异常的同步都直接跳过不管。是否可以设置为all,要结合项目的具体业务。本项目可以。
master_info_repository=table:可选< table | file >,设置为table更稳定,重启服务时可以自动续传
relay_log_info_repository=table:可选< table | file >,设置为table更稳定,重启服务时可以自动续传
log-slave-updates=1:配置为1表示开启级联复制
记得修改server-id,架构内互联的mysql均不能相同

server-id=100

②重启sql服务
③进入mysql命令行,执行以下命令

values为ON表示开启binlog成功

show variables like '%log_bin%';

有几个从主库,就创建几个账号,注意这个账号密码提前确定好记好,搞乱了就很头大:

CREATE USER '被同步库的账号名'@'被同步库的ip' IDENTIFIED BY '被同步库账号的密码'; GRANT REPLICATION SLAVE ON *.* TO '被同步库的账号名'@'被同步库的ip';

刷新权限:

flush privileges;

查看master状态:

show master status;

返回结果:

mysql如何实现多主双向和级联复制

这个形如"mysql-bin.000003"的值要记录上,从主库连接时要用
主主库的一阶段配置完成了

从主库:

①在mysql安装路径下找到启动文件my.ini或my.cnf,将如下信息放在启动文件的[mysqld]下:

log_bin=mysql-binbinlog_format=MIXEDsync_binlog=1expire_logs_days=7binlog-do-db=equip_systemslave-skip-errors=allmaster_info_repository=tablerelay_log_info_repository=table

以上参数和主主库是一样的,区别在于从主库不需要开启级联复制。记得修改server-id
后边过程和主主库的配置是一样的,毕竟都是开启master功能的,这里就不赘述了。把产出的形如"mysql-bin.000003"的值记录下来就好了

一阶段各个库的master功能配置完成

二阶段,配置各个库的slave功能,即将其与要同步的库建立连接

从主库只需跟主主库建立连接即可
在mysql命令行中执行以下命令:

设置连接master的参数:

CHANGE MASTER TO MASTER_HOST='要同步的对方库的ip', MASTER_PORT=对方库的端口号, MASTER_USER='对方库为你创建的账号名', MASTER_PASSWORD='对方库为你创建的密码',MASTER_LOG_FILE='对方库master状态产出的File的值';

启动slave建立连接:

start slave;

查看连接状态:

show slave status\G

返回结果:

mysql如何实现多主双向和级联复制

两个Running都为Yes时,表示连接成功了。不成功请自行查阅资料debug。我这里是对方库没开。
其余从主库操作一样,都是设置连接参数、启动slave建立连接、查看连接状态

主主库:

主主库流程同样是设置连接参数、启动slave建立连接、查看连接状态。不同点在于要设置多个master连接参数,所以设置连接参数的命令有一个小的变化,要多一个通道channel的设置,命令如下:
配置与从主库2的连接参数

CHANGE MASTER TO MASTER_HOST='从主库1的ip', MASTER_PORT='从主库1的端口号', MASTER_USER='从主库1为你创建的账号名', MASTER_PASSWORD='从主库1为你创建的密码',MASTER_LOG_FILE='从主库1的master状态的File值'for channel '1';

配置与从主库2的连接参数:

CHANGE MASTER TO MASTER_HOST='从主库2的ip', MASTER_PORT='从主库2的端口号', MASTER_USER='从主库2为你创建的账号名', MASTER_PASSWORD='从主库2为你创建的密码',MASTER_LOG_FILE='从主库2的master状态的File值'for channel '2';

有几个配几个:

...

启动slave:

start slave;

查看slave状态:

show slave status\G

返回结果有多个status,依次查看,依次核对即可。

以上是“mysql如何实现多主双向和级联复制”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql如何实现多主双向和级联复制

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql如何实现多主双向和级联复制

这篇文章主要为大家展示了“mysql如何实现多主双向和级联复制”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql如何实现多主双向和级联复制”这篇文章吧。一.解读在离线状态的切换,对于web
2023-06-26

Mysql如何实现主从配置和多主多从配置

这篇文章主要介绍了Mysql如何实现主从配置和多主多从配置,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。我们现在模拟的是主从(1台主机、一台从机),其主从同步的原理,就是对b
2023-06-15

Docker容器如何实现MySQL多源复制

今天小编给大家分享一下Docker容器如何实现MySQL多源复制的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。⛳️ 1.多源
2023-07-02

如何实现Linux内核多路镜像流量聚合和复制

这篇文章主要介绍“如何实现Linux内核多路镜像流量聚合和复制”,在日常操作中,相信很多人在如何实现Linux内核多路镜像流量聚合和复制问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何实现Linux内核多路
2023-06-13

如何在MySQL中实现数据库复制和高可用性

要在MySQL中实现数据库复制和高可用性,可以采用以下方法:MySQL复制:MySQL提供了内置的复制功能,可以使用主从复制或主主复制来实现数据库复制。主从复制是将数据从一个MySQL服务器(主服务器)复制到另一个MySQL服务器(从服务器
如何在MySQL中实现数据库复制和高可用性
2024-03-06

如何使用MySQL的复制功能实现高可用性和容错性?

如何使用MySQL的复制功能实现高可用性和容错性?随着互联网的快速发展,数据库的高可用性和容错性变得越来越重要。MySQL是一种广泛使用的开源关系型数据库,它的复制功能可以帮助我们实现数据库的高可用性和容错性。在本文中,我们将介绍如何使用M
2023-10-22

如何实现MySQL底层优化:数据备份和恢复的高级最佳实践

如何实现MySQL底层优化:数据备份和恢复的高级最佳实践摘要:MySQL是世界上最流行的关系型数据库管理系统之一,但在实际应用中,数据备份和恢复是非常重要的。本文将介绍MySQL底层优化中关于数据备份和恢复的高级最佳实践,并提供具体的代码示
如何实现MySQL底层优化:数据备份和恢复的高级最佳实践
2023-11-08

如何实现MySQL底层优化:事务的并发控制和隔离级别选择

如何实现MySQL底层优化:事务的并发控制和隔离级别选择摘要:在MySQL数据库中,事务的并发控制和隔离级别的选择对于数据库性能和数据一致性非常重要。本文将介绍如何通过底层优化来实现MySQL事务的并发控制和隔离级别选择,并提供具体的代码示
如何实现MySQL底层优化:事务的并发控制和隔离级别选择
2023-11-08

编程热搜

目录