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数据:

相关推荐
典学长编程34 分钟前
数据库Oracle从入门到精通!第四天(并发、锁、视图)
数据库·oracle
积跬步,慕至千里1 小时前
clickhouse数据库表和doris数据库表迁移starrocks数据库时建表注意事项总结
数据库·clickhouse
极限实验室2 小时前
搭建持久化的 INFINI Console 与 Easysearch 容器环境
数据库
星辰离彬2 小时前
Java 与 MySQL 性能优化:Java应用中MySQL慢SQL诊断与优化实战
java·后端·sql·mysql·性能优化
白仑色2 小时前
Oracle PL/SQL 编程基础详解(从块结构到游标操作)
数据库·oracle·数据库开发·存储过程·plsql编程
程序猿小D4 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
钢铁男儿4 小时前
C# 接口(什么是接口)
java·数据库·c#
__风__5 小时前
PostgreSQL kv(jsonb)存储
数据库·postgresql
轩情吖5 小时前
Qt的第一个程序(2)
服务器·数据库·qt·qt creator·qlineedit·hello world·编辑框
Databend5 小时前
Databend 产品月报(2025年6月)
数据库