欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 能源 > MySQL 主从复制原理及其工作过程的配置

MySQL 主从复制原理及其工作过程的配置

2025/4/24 22:34:38 来源:https://blog.csdn.net/2301_77430532/article/details/145243480  浏览:    关键词:MySQL 主从复制原理及其工作过程的配置

一、MySQL主从复制原理

        MySQL 主从同步是一种数据库复制技术,它通过将主服务器上的数据更改复制到一个或多个从服务器,实现数据的自动同步。

        主从同步的核心原理是将主服务器上的二进制日志复制到从服务器,并在从服务器上执行这些日志中的操作。

二、MySQL主从复制意义

  • 数据分布:主从复制支持数据跨服务器或地理分布,提升访问速度和可用性。
  • 灾备:如果主数据库出现问题,可以快速切换到从数据库,保证业务的连续性。
  • 读写分离:通过主从复制,可以实现数据库层面的读写分离,提高查询效率和系统性能。
  • 负载平衡:增加从数据库数量,分散读请求,避免单一服务器过载。
  • 提高并发能力:读写分离与从数据库扩展,结合优化措施,增强MySQL并发处理能力。

三、MySQL主从复制步骤

1、Master(主库)将用户对数据库更新的操作以二进制格式保存到BinLog日志文件中。

2、Slave(从库)从库通过手工执行change master to 语句连接主库,提供了连接的用户一切条件(user 、password、port、ip),并且让从库知道,二进制日志的起点位置(file名 position 号); start slave。

3、Slave的IO线程和主库的dump线程建立连接。

4、Slave的IO进程接收到信息后,将接收到的日志内容依次添加到Slave端的relay-log文件的最末端,并将读取到的Master端的bin-log的文件名和位置记录到master-info文件中,以便在下一次读取的时候能够清楚的告诉Master “我需要从某个binlog的哪个位置开始往后的日志内容,请发给我”。
5、Master的dump线程根据从库的请求,将本地binlog以events的方式发给从库IO线程。
6、SlaveIO线程接收binlog events,并存放到本地relay-log中,传送过来的信息,会记录到master.info中。
7、SlaveSQL线程应用relay-log,并且把应用过的记录到relay-log.info中,默认情况下,已经应用过的relay 会自动被清理purge。

四、注意事项

  • 版本兼容性:为了确保复制的顺利进行,主从节点的MySQL版本最好相同(或不应高于从节点)。
  • 延迟问题:由于复制是异步的,可能会出现主从数据不一致的情况,这是主从复制中的一个常见问题。
  • 不能代替备份:主从复制不能完全代替数据备份,因为主节点上的误操作也会同步到从节点。

五、部署实操

1、基于binlog的主从同步

Master配置
[root@Master ~]# yum install -y mysql-server#配置文件,注意://三台主从库的id必须不同
[root@Master ~]# vim /etc/my.cnf.d/mysql-server.cnf
server_id=1     //直接在后面添加 
[root@Master ~]# systemctl restart mysqld#授权用户
mysql> create user rep@'192.168.1.%' identified with mysql_native_password by '123456';
mysql> grant replication slave on *.* to rep@'192.168.1.%';
mysql> show master status;  //查看主服务器状态,日志用于从服务器同步,position是当前定位

Slave配置
#配置文件
[root@Slave1 ~]# vim /etc/my.cnf.d/mysql-server.cnf
server_id=2
[root@Slave1 ~]# systemctl restart mysqld[root@Slave3 ~]# vim /etc/my.cnf.d/mysql-server.cnf
server_id=3
[root@Slave3 ~]# systemctl restart mysqld#设置复制参数,两个Slave一样的配置
mysql> change master to-> master_host='192.168.1.11',-> master_user='rep',-> master_password='123456',-> master_log_file='binlog.000001',-> master_log_pos=1640,-> get_master_public_key=1;#启动复制进程,两个Slave都启动
mysql> start slave;

查看从库状态

 注意:我的Slave3机子直接克隆的master的,导致uuid一样结果出错了。

解决:进入/var/lib/mysql下查看auto.cnf,查看server-uuid对比一下三台机子各不同,和主库(master)冲突,在从库(salve3)上修改的。直接删除auto.cnf,重启mysql服务。会生成新的不一样的auto.cnf。

 验证:

主库(Master)建表,在从库(Slave1和3)上能看到主库创建的表db1,复制完成。

2、 基于gtid的主从同步配置

准备工作,停止从库(Slave1和3)的复制

确保从库的复制状态已经停止,可以通过运行show slave status \G命令来检查。

Slave1:

Slave3:

Master配置
#修改配置文件
[root@Master ~]# vim /etc/my.cnf.d/mysql-server.cnf
#在最后添加
gtid_mode=ON
enforce-gtid-consistency=ON#重启MySQL服务
[root@Master ~]# systemctl restart mysqld.service#重置二进制日志和GTID
mysql> reset master;#创建用户授予权限
mysql> create user rep@'192.168.1.%' identified with mysql_native_password by '123456';  //报错不影响因为之前创建过
mysql> grant replication slave on *.* to rep@'192.168.1.%';#重新加载授权表
mysql> flush privileges;
Slave配置
#Slave1和3相同配置#修改配置文件
[root@Slave1 ~]# vim /etc/my.cnf.d/mysql-server.cnf
gtid_mode=ON
enforce-gtid-consistency=ON#重启服务
[root@Slave1 ~]# systemctl restart mysqld.service#配置连接到主库
mysql> change replication source to-> source_host='192.168.1.11',-> source_port=3306,-> source_user='rep',-> source_password='123456',-> source_auto_position=1;mysql> start replica;

查看从库状态 

 

验证:

 主库(Master)建表,在从库(Slave1和3)上能看到主库创建的表student1,复制完成。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词