Mysql的主从复制和读写分离

一.主从复制

主从复制的作用:

读写分离

读写分离

具有高可用性

主从复制的工作过程:

主服务器master发生数据变化时,会记录到二进制日志中;从服务器slave会开启io线程请求二进制日志事件;主服务器会为每个io线程开启dump线程并发送二进制日志事件;从服务器会将二进制日志事件保存到中继日志中;从服务器开启sql线程,读取中继日志中的二进制日志事件并解析进行重放;在5.7版本开启半同步复制下,主服务器会用ack collector线程接受从服务器的相应确认消息。

MySQL 读写分离原理:

读写分离就是只在主服务器上写,只在从服务器上读。基本的原理是让主数据库处理事务性操作,而从数据库处理 select 查询。

目前较为常见的 MySQL 读写分离分为以下两种:

基于程序代码内部实现:在代码中根据 select、insert 进行路由分类,这类方法也是目前生产环境应用最广泛的。

基于中间代理层实现:代理一般位于客户端和服务器之间,代理服务器接到客户端请求后通过判断后转发到后端数据库,有以下代表性程序。

Amoeba该程序由Java语言进行开发,阿里巴巴将其用于生产环境。但是它不支持事务和存储过程。

Mycat是一款流行的基于Java语言编写的数据库中间件,是一个实现了MySql协议的服务器,其核心功能是分库分表。配合数据库的主从模式还可以实现读写分离。

mysql支持的复制类型:

STATEMENT:基于语句的复制。在服务器上执行sql语句,在从服务器上执行同样的语句,mysql默认采用基于语句的复制,执行效率高。

ROW:基于行的复制。把改变的内容复制过去,而不是把命令在从服务器上执行一遍。

MIXED:混合类型的复制。默认采用基于语句的复制,一旦发现基于语句无法精确复制时,就会采用基于行的复制。

半同步复制什么情况下会转到异步复制?

当半同步复制发生超时(由rpl_semi_sync_master_timeout参数控制,默认为10000ms,即10s),会暂时关闭半同步复制,转而使用异步复制,也就是会自动降为异步工作。

当 master dump 线程发送完一个事务的所有事件之后,如果在 rpl_semi_sync_master_timeout 内,收到了从库的响应, 则主从又重新恢复为半同步复制。

二.搭建 MySQL主从复制

我们需要一台做主服务和两台做从服务器进行主从复制。

先检查每个服务器的mysql开启:

配置主服务器test1时间同步:

修改其配置文件:

查看时间:

到从服务器看时间同步:

test2:

添加计划任务:

test3:

配置主服务器:
登录mysql进行给从服务器授权:
配置从服务器:

修改配置文件:

登录数据库配置主从同步:

看下主服务器的状态:

从服务器test2:

开启同步:

查看 Slave 状态:

从服务器test3:

修改配置文件:

登录数据库实现同步:

测试主从复制:

看下主从服务器的库:

给主服务添加创建库:

这样就实现了主从复制。

MySQL主从复制延迟:

通过监控show slave statuslG命令输出的Seconds Behind Master参数的值来判断,是否有发生主从延时。

mysql主从复制延迟原因:

1、master服务器高并发,形成大量事务

2、网络延迟

3、主从硬件设备导致cpu主频、内存io、硬盘io

4、是同步复制、而不是异步复制

如何优化减少主从延迟:

从库优化Mysql参数。比如增大innodb_buffer_pool_size,让更多操作在Mysql内存中完成,减少磁盘操作。

从库使用SSD磁盘

从库使用高性能主机

网络优化,避免跨机房实现同步

三.搭建mysql读写分离

开启一台服务器,安装java环境:

添加权限:

将amoeba软件包移动过去:

切换到/usr/local/amoeba目录下,解压amoeba:

添加变量:

看下当前java版本:


开启amoeba:

到主从服务器添加授权:
配置amoeba的配置文件:

添加数据:

在添加数据:

添加test3数据:

相关推荐
学计算机的计算基1 分钟前
MySQL 锁体系全解:从 MDL 到间隙锁,一次讲透
java·数据库·笔记·python·mysql
Trouvaille ~3 分钟前
【Redis篇】Redis 事务:原子性与脚本执行机制
数据库·redis·后端·算法·junit·lua·原子性
努力攻坚操作系统6 分钟前
Elasticsearch 完全教学指南:从入门到精通
大数据·数据库·elasticsearch·搜索引擎·全文检索
睡不醒男孩0308239 分钟前
行业解决方案二:CLup打造企业级数据库私有云(DBaaS)平台解决方案
数据库·云计算·clup
猴哥聊项目管理10 分钟前
2026年信创项目管理:如何用甘特图提升进度管控
大数据·数据库·项目管理·企业数字化转型·甘特图·敏捷开发·项目进度管理软件
j7~18 分钟前
MySQL C语言连接库和MYSQL连接池原理与简易数据网站数据流动是如何进行的
c语言·数据库·mysql·连接池·mysqlc语言连接库
暗夜猎手-大魔王30 分钟前
转载--Hermes Agent 10 | 7 层安全防线:从用户授权到输入净化
java·数据库·安全
weelinking9 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
稳联技术老娜9 小时前
DeviceNet主站怎么连接西门子PLC,Profinet网关配置手册(那智机器人)
服务器·网络·数据库
这个DBA有点耶9 小时前
云上运维新挑战:当数据库不再“看得见摸得着”
数据库·sql·程序人生·云原生·运维开发·学习方法·dba