半同步复制为了保证Master出现问题时,至少存在一台slave的数据是完整的。超时情况下半同步复制也会转换为异步复制,以保障主库业务的正常更新。在一定程度上保证了所提交事务至少发送给一个slave。但仅仅保证事务已经传递到了slave上,不能保证应用到了slave数据库。
基础环境
角色 | hostname | eth0(业务) | eth1(主从同步) |
master | node5 | 10.11.12.5 | 172.16.33.5 |
slave | node6 | 10.11.12.6 | 172.16.33.6 |
配置文件 my.cnf
半同步复制my.cnf参数对比 | |
Master1 | Master2 |
[client] user = root password = root1234 [mysqld] server_id = 5 basedir = /app/mysql5.7 datadir = /app/mysql5.7/data log_bin = /app/mysql5.7/logs/ocean-bin expire_logs_days = 7 [mysqld_safe] log-error = /app/mysql5.7/logs/ocean.err sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_STABLES | [client] user = root password = root1234 [mysqld] server_id = 6 basedir = /app/mysql5.7 datadir = /app/mysql5.7/data log_bin = /app/mysql5.7/logs/ocean-bin log_slave_updates expire_logs_days = 7 [mysqld_safe] log-error = /app/mysql5.7/logs/ocean.err sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_STABLES |
配置主从复制
半同步复制的基础是主从复制环境,参考《MySQL数据库复制技术 Part 2 : 主从复制》
半同步复制插件配置
MySQL 5.5 版本开始支持半同步复制,因此,无须额外安装软件,默认情况下,半同步软件在MySQL安装目录
--- 插件所在路径
cd /app/mysql5.7/lib/plugin
ls -rlth | grep semi*
主库安装插件&配置
--- Master 安装插件
install plugin rpl_semi_sync_master soname 'semisync_master.so';
--- 临时开启半同步复制
set global rpl_semi_sync_master_enabled = ON;
--- 设置Master等待slave确认消息的时长(超时时间)
set global rpl_semi_sync_master_timeout = 10000;
--- 永久开启半同步复制
vi /etc/my.cnf
[mysqld]
rpl_semi_sync_master_enabled = ON
rpl_semi_sync_master_timeout = 10000
--- 检查主库开启及配置的插件生效方法
select * from mysql.plugin;
--- 查看INFORMATION_SCHEMA库表
show plugins;
--- 查看主库半同步复制的状态
show global status like '%semi%';
--- 查看主库半同步复制的参数
show global variables like '%semi%';
半同步复制参数说明
参数 | 说明 |
rpl_semi_sync_master_enabled | ON:开启半同步复制 OFF:关闭 |
rpl_semi_sync_master_timeout | 单位:毫秒,默认值:10000毫秒 master等待slave的更新时间,超时后,自动降级为异步复制,当master监测到可以连接slave,则自动回到半同步复制模式 |
rpl_semi_sync_master_wait_no_slave | master每个事务提交后等待slave接受确认信息,默认为ON |
rpl_semi_sync_master_trace_level | 半同步复制模式的信息输出级别,默认为32 |
半同步复制状态说明
状态 | 说明 |
rpl_semi_sync_master_clients | 查看半同步复制模式的slave数 |
rpl_semi_sync_master_net_avg_wait_time | master等待slave回复的平均网络等待时间 |
rpl_semi_sync_master_net_wait_time | master网络等待时间 |
rpl_semi_sync_master_net_waits | master等待slave回复的网络等待次数 |
rpl_semi_sync_master_no_times | master关闭半同步复制的次数 |
rpl_semi_sync_master_no_tx | 未使用半同步复制事务数(master等待超时的次数) |
rpl_semi_sync_master_status | master是否为半同步复制模式 |
rpl_semi_sync_master_timefunc_failures | |
rpl_semi_sync_master_tx_avg_wait_time | master的每事务平均等待时间 |
rpl_semi_sync_master_tx_wait_time | master的总事务等待时间 |
rpl_semi_sync_master_tx_waits | master等待slave回复总的事务等待次数 |
rpl_semi_sync_master_wait_pos_backtraverse | 后来的先到了,先来的还没有到的次数 |
rpl_semi_sync_master_wait_sessions | slave回复造成等待的session数 |
rpl_semi_sync_master_yes_tx | 半同步复制的事务数(master成功接收slave回复数) |
从库安装插件&配置
--- 从库安装插件
INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
--- slave临时开启半同步
SET GLOBAL rpl_semi_sync_slave_enabled = ON;
--- slave永久开启半同步,配置my.cnf
[mysqld]
rpl_semi_sync_slave_enabled = ON
--- 查看复制状态
show slave status\G;
--- 停止I/O线程、启动I/O线程
stop slave io_thread;
start slave io_thread;
--- 查看从库半同步复制的状态
show global status like '%semi%';
--- 查看从库半同步复制的参数
show global variables like '%semi%';
生产环境半同步复制方案
常规的互联网应用,主从复制技术能够满足需求。数据一致性要求高的应用可以使用半同步复制方案,但半同步复制技术也存在短板,主库的更新性能受到影响,在slave网络不稳定时会尤为明显。
优化方案:
- master半同步超时改小(1 - 2 秒)
- slave服务器的网络配置要更高
- slave不提供服务
相关链接