前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL5.7主从复制-半同步复制搭建札记

MySQL5.7主从复制-半同步复制搭建札记

作者头像
星哥玩云
发布2022-08-16 14:46:56
9510
发布2022-08-16 14:46:56
举报
文章被收录于专栏:开源部署

两台服务器,系统是RedHat6.5,MySQL版本是5.7.18。

1、打开主库和从库的MySQL服务,然后安装插件,半同步复制插件在目录/usr/local/mysql/lib/plugin下

在主库安装semisync_master.so插件:

mysql> install plugin rpl_semi_sync_master soname 'semisync_master.so';

Query OK, 0 rows affected (0.02 sec) mysql> set global rpl_semi_sync_master_enabled=ON; Query OK, 0 rows affected (0.04 sec)

在从库安装semisync_slave.so插件:

mysql> install plugin rpl_semi_sync_slave soname 'semisync_slave.so';

Query OK, 0 rows affected (0.02 sec) mysql> set global rpl_semi_sync_slave_enabled=ON; Query OK, 0 rows affected (0.00 sec) 注意:初次加载插件后,MySQL会将该插件记录到系统表mysql.plugin中,下次启动时系统会自动加载该插件。 2、在my.cnf配置文件里加入以下配置: rpl-semi-sync-master-enabled = 1  rpl-semi-sync-slave-enabled = 1

master上主要的四个参数: rpl_semi_sync_master_enabled=ON:表示在master上已经开启半同步复制模式。 rpl_semi_sync_master_timeout=10000:该参数默认为10000毫秒,即10秒,可以调整,表示如果主库在某次事务中等待事件超过10秒,则降级为异步复制模式,不再等待slave,如果master探测到slave恢复,则会自动回到半同步模式。 rel_semi_synv_master_wait_no_slave:表示是否允许master每个事务提交后都要等待slave的确认信号,默认是ON,即每一个事务都会等待,如果是OFF,则slave追赶上之后,也不会回到半同步模式。 rlp_semi_sync_master_trace_level=32:表示开启半同步复制模式时的调试级别,默认是32。

slave上主要的两个参数: rpl_semi_sync_slave_enabled=ON:表示在slave上开启半同步复制模式。 rlp_semi_sync_slave_trace_level=32:表示开启半同步复制模式时的调试级别,默认是32。

3、在主库上,创建复制使用的用户,并授予replication slave权限。这里创建用户repl,可以从IP为10.10.10.210的主机进行连接。 grant replication slave on *.* to 'repl'@'10.10.10.210' identified by 'mysql';

4、修改主服务器配置,加入如下配置: cat /etc/my.cnf [mysqld] server-id=1 log-bin=mysql-bin log-bin-index=mysql-bin.index binlog_format=mixed

5、在主库上,设置读锁,确保没有数据操作,获得一个一致性的快照 flush tables with read lock;

6、然后在主库上获得当前二进制日志名和偏量值,改操作的目的是从库启动之后,从这个点开始恢复数据。

mysql> show master status;

+------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +------------------+----------+--------------+------------------+-------------------+ | mysql-bin.000006 | 120 | | | | +------------------+----------+--------------+------------------+-------------------+ 7、利用mysqldump导出数据,拷贝至从库服务器。

8、主库备份完成,恢复写操作 unlock tables;

9、修改从库的配置文件,添加如下参数,注意server-id必须是唯一的,不能和主库相同,多个从库的话,server-id不能有重复。 cat /etc/my.cnf [mysqld] server-id=2

10、在从库上,使用--skip-slave-start启动数据库,这样不会立即启动从库上的复制进程,方便我们进行下一步配置。 ./bin/mysqld_safe --skip-slave-start &

11、对从库进行配置,指定复制使用的用户,主库的IP、端口以及开始执行复制的日志文件和位置等: change master to master_host='10.10.10.200', master_port=3306, master_user='repl', master_password='mysql', master_log_file='mysql-bin.000006', master_log_pos=120;

12、在从库上启动slave线程 start slave;

13、验证半同步模式是否开始工作

在master上查看状态:

mysql> show status like '%semi%';

+--------------------------------------------+-------+ | Variable_name | Value | +--------------------------------------------+-------+ | Rpl_semi_sync_master_clients | 1 | | Rpl_semi_sync_master_net_avg_wait_time | 0 | | Rpl_semi_sync_master_net_wait_time | 0 | | Rpl_semi_sync_master_net_waits | 0 | | Rpl_semi_sync_master_no_times | 0 | | Rpl_semi_sync_master_no_tx | 0 | | Rpl_semi_sync_master_status | ON | | Rpl_semi_sync_master_timefunc_failures | 0 | | Rpl_semi_sync_master_tx_avg_wait_time | 0 | | Rpl_semi_sync_master_tx_wait_time | 0 | | Rpl_semi_sync_master_tx_waits | 0 | | Rpl_semi_sync_master_wait_pos_backtraverse | 0 | | Rpl_semi_sync_master_wait_sessions | 0 | | Rpl_semi_sync_master_yes_tx | 0 | | Rpl_semi_sync_slave_status | OFF | +--------------------------------------------+-------+

在slave上查看状态:

mysql> show status like '%semi%';

+--------------------------------------------+-------+ | Variable_name | Value | +--------------------------------------------+-------+ | Rpl_semi_sync_master_clients | 0 | | Rpl_semi_sync_master_net_avg_wait_time | 0 | | Rpl_semi_sync_master_net_wait_time | 0 | | Rpl_semi_sync_master_net_waits | 0 | | Rpl_semi_sync_master_no_times | 0 | | Rpl_semi_sync_master_no_tx | 0 | | Rpl_semi_sync_master_status | OFF | | Rpl_semi_sync_master_timefunc_failures | 0 | | Rpl_semi_sync_master_tx_avg_wait_time | 0 | | Rpl_semi_sync_master_tx_wait_time | 0 | | Rpl_semi_sync_master_tx_waits | 0 | | Rpl_semi_sync_master_wait_pos_backtraverse | 0 | | Rpl_semi_sync_master_wait_sessions | 0 | | Rpl_semi_sync_master_yes_tx | 0 | | Rpl_semi_sync_slave_status | ON | +--------------------------------------------+-------+

14、在master通过DDL和DML操作进行同步效果验证。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档