Mysql的主从复制和读写分离

发布时间:2024年01月02日

一.主从复制

主从复制的作用:

读写分离

读写分离

具有高可用性

主从复制的工作过程:

主服务器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的配置文件:

navicat软件测试:

添加数据:

在添加数据:

添加test3数据:

文章来源:https://blog.csdn.net/2302_79748698/article/details/135341746
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。