两台服务器, 系统是 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 mailto:'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 操作进行同步效果验证.
来源: http://www.linuxidc.com/Linux/2018-04/151844.htm