本文主要是介绍MySQL数据库复制技术 Part 5 : 半同步复制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
半同步复制为了保证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/pluginls -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不提供服务
相关链接
MySQL数据库复制技术 Part 1 : 复制技术介绍
MySQL数据库复制技术 Part 2 : 主从复制
MySQL数据库复制技术 Part 3 : 级联复制
MySQL数据库复制技术 Part 4 : 双主复制
MySQL数据库复制技术 Part 6 : GTID复制
这篇关于MySQL数据库复制技术 Part 5 : 半同步复制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!