MYSQL——主从复制的原理及实验步骤

MYSQL——主从复制的原理及实验步骤


一、什么是mysql的主从复制?

主从复制,是指使用两个或两个以上的相同数据,其中一个当主数据库(master),而另一个当从数据库(slave)。而在主数据库上进行的所有操作,从数据库都会一一记录,达到两者一模一样。

二、mysql主从复制的原理

1.主从复制原理图

在这里插入图片描述

2.主从复制原理描述

1、主服务器MySQL服务将所有的写操作记录在binlog日志中,并生成log dump线程,将binlog日志传给从服务器MySQL服务的I/O线程。

2、从服务器MySQL服务生成两个线程,-个是I/O线程,另一个是SQL线程。

3、从库I/O线程去请求主库的binlog日志,并将binlog日志中的文件写入relaylog (中继日志)中。

4、从库的SQL线程会读取relaylog中的内容,并解析成具体的操作,来实现主从的操作一致, 达到最终两个数据库数据一致的目的。

三、mysql主从复制项目的步骤

1.项目环境准备

准备2台2c/4G的服务器(虚拟机),安装相同版本的虚拟机(建议centos7.6),安装部署好mysql 5.7.33

2.实验步骤

黑底图片为master上的操作,白底图片为slave上操作
1.准备好2台安装好系统的机器,使用脚本一键部署好二进制版本的MySQL,并且设置好my.cnf配置文件的内容。
2.在master服务器上开启二进制日志和配置server_id,从服务器上配置server_id
在这里插入图片描述

3.在master上创建给slave过来复制二进制日志的用户
在这里插入图片描述
4.在master上做一个全备,导出数据导入到slave上,保持master和slave上的数据一致
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
5.在slave上配置去master上拉取二进制日志的用户名和密码以及日志文件的名称和位置号等信息

查看位置号和端口号

在这里插入图片描述

 配置slave

在这里插入图片描述
6.在master和slave都关闭防火墙和selinux
在这里插入图片描述
此时 Slave_IO_Running: No
Slave_SQL_Running: No

在这里插入图片描述

7.在slave服务器上启动 slave服务,查看IO线程和SQL线程是否正常启动

start slave;

重复上述操作,可以看到:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

8.验证主从复制的效果
在这里插入图片描述
在这里插入图片描述

四、mysql的主从复制作用?

1、做数据的热备,作为后备数据库,主数据库服务器故障后,可切换到从数据库继续工作,避免数据丢失。
2、架构的扩展。业务量越来越大,I/O访问频率过高,单机无法满足,此时做多库的存储,降低磁盘I/O访问的频率,提高单个机器的I/O性能。
3、读写分离,使数据库能支撑更大的并发。在报表中尤其重要。由于部分报表sql语句非常的慢,导致锁表,影响前台服务。如果前台使用master,报表使用slave,那么报表sql将不会造成前台锁,保证了前台速度。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值