数据库主从复制

张春  论坛元老 | 2024-7-31 07:19:48 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 1005|帖子 1005|积分 3015

目录
一.主从复制架构
二.主从复制原理
三.实现主从复制配置
1.新建主从复制
2.实战遇到题目
3.复制错误解决方法
4.级联 主从复制
5.半同步复制


MySQL数据库的主从复制(Master-Slave Replication)是一种常见的数据库复制架构,用于提高数据库的可用性、可靠性和性能。
一.主从复制架构

在MySQL主从复制中,通常涉及以下几个角色:

  • 主服务器(Master)

    • 主服务器是数据库的主要写入节点。
    • 所有的写操纵(INSERT、UPDATE、DELETE)以及数据定义语言(DDL)语句(如CREATE TABLE、ALTER TABLE)都在主服务器上实行。
    • 主服务器将其实行的所有变更记录到二进制日记(Binary Log)中。

  • 从服务器(Slave)

    • 从服务器是主服务器的备份节点,用于读操纵和备份。
    • 从服务器从主服务器上的二进制日记复制数据变更,并将这些变更应用到本身的数据副本中。
    • 从服务器可以用于读取查询操纵,从而减轻主服务器的负载。

  • 二进制日记(Binary Log)

    • 主服务器记录所有变更操纵的详细信息到二进制日记中。
    • 从服务器通过读取主服务器的二进制日记来获取主服务器上发生的数据变更。

二.主从复制原理


   1主节点负责用户的写操纵,用户发起写操纵后,会修改数据库
2.数据库修改后,会更新主节点上的二进制日记
  4.从服务器会开启io线程,主动请求与主服务器同步
3.主服务器会产生一个  dump线程, 一边读取二进制日记一边将二进制日记通过 网络传给从服务器
5 io线程会将主服务器的二进制日记写入从服务器的中继日记,这时只是天生了一个文件,并没有同步
6.从服务器再开启  sql线程将 中继日记中  操纵写入数据库完成更新
  主从复制相关线程
   dump Thread:为每个Slave的I/O Thread启动一个dump线程,用于向其发送binary log events从节点
  I/O Thread:向Master请求二进制日记变乱,并生存于中继日记中
  SQL Thread:从中继日记中读取日记变乱,在本地完成同步
  跟复制功能相关的文件:
   master.info:用于生存slave连接至master时的相关信息,例如账号、密码、服务器地点等
  relay-log.info:生存在当前slave节点上已经复制的当前二进制日记和本地relay log日记的对应关系
  mysql-relay-bin.00000#: 中继日记,生存从主节点复制过来的二进制日记,本质就是二进制日记
  
  中继日记 (relay log)只在主从服务器架构的从服务器上存在。从服务器(slave)为了与主服务器(Master)保持同等,要从主服务器读取二进制日记的内容,并且把读取到的信息写入本地的日记文件中,这个从服务器本地的日记文件就叫中继日记。然后,从服务器读取中继日记,并根据中继日记的内容对从服务器的数据举行更新,完成主从服务器的数据同步
主从复制(Master-Slave Replication)是数据库中常见的一种复制方式,其主要特点包括:

  • 数据复制: 主从复制是将一个数据库(主数据库)的数据复制到一个或多个其他数据库(从数据库)的过程。主数据库的更新操纵(写操纵)会被记录并同步到所有从数据库上,从而保持数据的同等性。
  • 异步复制: 典范的主从复制是异步举行的,即主数据库实行写操纵后,并不等候所有从数据库都接收并应用该操纵,而是立即返回给客户端。从数据库在稍后的时间点异步地从主数据库获取更新,并应用到本身的数据集上。
  • 读写分离: 主从复制可以实现读写分离,即主数据库负责处置处罚写操纵(写入数据),而从数据库负责处置处罚读操纵(读取数据)。这种架构可以有效分担主数据库的读写压力,提高整体性能。
  • 容灾和备份: 通过主从复制可以实现数据的容灾备份。假如主数据库发生故障,可以快速切换到某个从数据库继续提供服务,从而保证体系的可用性和长期性。
  • 分布式数据: 主从复制可以用于在差别地理位置的数据库之间同步数据,从而实现分布式数据管理和协作。
  • 延迟复制: 由于主从复制是异步的,从数据库上的数据更新大概会有一定的延迟,这取决于网络延迟、主从数据库的负载等因素。因此,在某些情况下需要考虑到延迟带来的数据同等性题目。
复制需要考虑二进制日记变乱记录格式


  • STATEMENT(5.0之前), Mariadb5.5 默认利用此格式
  • ROW(5.1之后,推荐),MySQL 8.0 默认利用此格式
  • MIXED: Mariadb10.3 默认利用此格式
三.实现主从复制配置

官网参考
   https://dev.mysql.com/doc/refman/8.0/en/replication-configuration.html
https://dev.mysql.com/doc/refman/5.7/en/replication-configuration.html
https://dev.mysql.com/doc/refman/5.5/en/replication-configuration.html
https://mariadb.com/kb/en/library/setting-up-replication/
  1.新建主从复制

   主服务器:192.168.240.11
  从服务器:192.168.240.14
  (1)主从服务器关闭防火墙和selinux
  1. systemctl stop firewalld
  2. setenforce  0
复制代码
(2)主从复制主服务器配置
  1. #开启二进制日志
  2. vim  /etc/my.cnf
  3. [mysqld]
  4. server-id=11
  5. log-bin=/data/mysql/mysql-bin
  6. mkdir  -p /data/mysql
  7. chown  -R mysql.mysql  /data
  8. systemctl restart  mysqld
复制代码


(3)从服务器配置
  1. #开启二进制日志
  2. vim  /etc/my.cnf
  3. [mysqld]
  4. server-id=14
  5. log-bin=/data/mysql/mysql-bin
  6. #read only  #只读可加
  7. mkdir  -p /data/mysql
  8. chown  -R mysql.mysql  /data
  9. systemctl restart  mysqld
复制代码



(4)主服务器登录数据库,新建同步用户
  1. grant replication slave on *.* to cxk@'%' identified by 'Admin@123';
  2. #新建用户,同时授权用户,mysql 8.0 以上需要分开写
  3. show master status;   #查看同步文件和 同步的位置
复制代码

(5)从服务器登录数据库,添加主的信息
  1. help change master to;
  2. #查看帮助信息,复制信息并修改
  3. CHANGE MASTER TO
  4.   MASTER_HOST='192.168.240.11',
  5.   MASTER_USER='cxk',
  6.   MASTER_PASSWORD='Admin@123',
  7.   MASTER_PORT=3306,
  8.   MASTER_LOG_FILE='mysql-bin.000001',
  9.   MASTER_LOG_POS=436;
复制代码

(6)开启io线程和sql线程,查看服务器状态
  1. start slave;#开启io线程 以及sq| 线程
  2. show processlist;#看到进程列表
  3. show slave status\G; # 查看从服务器状态
复制代码


(7)测试主从复制
  1. 在主服务器上新建zxy库,查看从服务器有没有同步
  2. create  database  zxy;
  3. show databases;
  4. 从服务器
  5. show databases;
复制代码

2.实战遇到题目

假设主节点的数据库已经运行了一段时间,产生了一定量的数据,主从复制只能复制开启后数据,那之前的数据如何处置处罚?
   主服务器:192.168.240.11
  从服务器:192.168.240.14
   (1)主从服务器关闭防火墙和selinux
  1. systemctl stop firewalld
  2. setenforce  0
复制代码
(2)主从复制主节点配置
导入hellodb数据库
  1. mysql  -uroot -p123123  <  /opt/hellodb_innodb.sql
复制代码
  1. #开启二进制日志
  2. [root@localhost ~]#vim  /etc/my.cnf
  3. server-id=11
  4. log-bin=/data/mysql/mysql-bin
  5. [root@localhost ~]# mkdir  -p  /data/mysql/binlog
  6. [root@localhost ~]# chown mysql.mysql /data/  -R
  7. [root@localhost ~]# systemctl  restart  mysqld
  8. mysqldump -uroot -p123123 -A -F --master-data=1  --single-transaction > /data/all.sql
复制代码

(3)从服务器上配置
  1. [root@localhost ~]#vim  /etc/my.cnf
  2. server-id=14
  3. log-bin=/data/mysql/mysql-bin
  4. #read only  #只读可加
  5. mkdir  -p  /data/mysql/binlog
  6. chown mysql.mysql /data/  -R
  7. systemctl  restart  mysqld
复制代码
 (4)主服务器登录数据库,新建同步用户
  1. grant replication slave on *.* to cxk@'%' identified by 'Admin@123';
  2. #新建用户,同时授权用户,mysql 8.0 以上需要分开写
  3. scp -r /data/all.sql   192.168.240.14:/opt
  4. #将完全备份文件拷贝到从服务器上
复制代码

(5)从服务器上编辑从主服务器拷贝的完全备份文件
  1. [root@localhost ~]# vim  /opt/all.sql
  2. #  找到    CHANGE MASTER TO  的行修改如下
  3. CHANGE MASTER TO
  4.   MASTER_HOST='192.168.240.11',
  5.   MASTER_USER='cxk',
  6.   MASTER_PASSWORD='Admin@123',
  7.   MASTER_PORT=3306,
  8.   MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=154;
  9. #由于之前再备份的时候加入了    --master-data=1 选项    就添加了主从复制的选项000002文件的154位置往后开始主从复制
  10. #000002文件154位置之前的  配置由  备份文件自行实现
复制代码

(6)进入数据库关闭二进制日记导入完全备份数据库
  1. mysql  -uroot -p123123
  2. set sql_log_bin=0;
  3. source /opt/all.sql ;
  4. start  slave;
  5. show slave status\G;  
复制代码

(7)查看数据库

3.复制错误解决方法

可以在从服务器忽略几个主服务器的复制变乱,此为global变量,或指定跳过变乱的ID
  1. #系统变量,指定跳过复制事件的个数
  2. SET GLOBAL sql_slave_skip_counter = N
  3. #服务器选项,只读系统变量,指定跳过事件的ID
  4. [mysqld]
  5. slave_skip_errors=1007|ALL  
复制代码
复制冲突的解决
  1. create table info (id int,name char(10),age char(10));
  2. #先在从上建表
  3. #再在主上建表  插入信息
  4. create table info (id int,name char(10),age char(10));
  5. insert info values(1,'a',10);
  6. #此时报错 从主机会报错
  7. show  slave  status\G
  8. #可以跳过错误
  9. stop slave;
  10. set global sql_slave_skip_counter=1;
  11. start slave;
  12. #方法2
  13. vim /etc/my.cnf.d/mariadb-server.cnf
  14. [mysqld]
  15. slave_skip_errors=1007|ALL
  16. #systemctl restart mysqld
复制代码
 更换主从
  1. reset slave  all;
  2. #清空主从配置
复制代码
4.级联 主从复制

需要在中央的从服务器启用以下配置 ,实现中央slave节点能将master的二进制日记在本机举行数据库更新,并且也同时更新本机的二进制,从而实现级联复制
   主服务器:192.168.240.11
  中央节点:192.168.240.12
  从节点1:192.168.240.13
  从节点2:192.168.240.14
   (1)主从服务器关闭防火墙和selinux
  1. systemctl stop firewalld
  2. setenforce  0
复制代码
(2)主服务器配置
  1. #开启二进制日志
  2. [root@localhost ~]#vim  /etc/my.cnf
  3. server-id=11
  4. log-bin=/data/mysql/mysql-bin
  5. [root@localhost ~]# mkdir  -p  /data/mysql/binlog
  6. [root@localhost ~]# chown mysql.mysql /data/  -R
  7. [root@localhost ~]# systemctl  restart  mysqld
  8. select @@server_id;
  9. #可以查看serverid  默认都是1
  10. show master status;
  11. #查看二进制日志位置
  12. grant replication slave on *.* to cxk@'%' identified by 'Admin@123';
复制代码



(2)中央节点
  1. root@localhost ~]#vim  /etc/my.cnf
  2. #修改文件
  3. [mysqld]
  4. server_id=12
  5. log-bin=/data/mysql/mysql-bin
  6. relay-log=relay-log-bin
  7. relay-log-index=slave-relay-bin.index
  8. log_slave_updates
  9. #read-only  #只读可加
  10. [root@localhost ~]#mkdir /data/mysql/   -p
  11. #建立文件夹
  12. [root@localhost ~]#chown mysql.mysql /data/ -R
  13. #注意修改权限
  14. [root@localhost ~]#systemctl restart mysqld
复制代码

  1. 下面修改配置 命令较长可以使用帮助
  2. help change master to
  3. CHANGE MASTER TO
  4.   MASTER_HOST='192.168.240.11',
  5.   MASTER_USER='cxk',
  6.   MASTER_PASSWORD='Admin@123',
  7.   MASTER_PORT=3306,
  8.   MASTER_LOG_FILE='mysql-bin.000003',
  9.   MASTER_LOG_POS=436;
  10. start slave;
  11. #开启线程,开启主从复制
  12. show slave status\G;
  13. #查看设置的状态
复制代码

  1. show master logs;
  2. #查看  从节点的复制位置
复制代码

  1. grant replication slave on *.* to cxk@'%' identified by 'Admin@123';
  2. 创建用户,用于连接数据库
复制代码
(3)从节点1
  1. [root@localhost ~]#vim  /etc/my.cnf
  2. server-id=13
  3. log-bin=/data/mysql/mysql-bin
  4. #read only  #只读可加
  5. mkdir  -p  /data/mysql/binlog
  6. chown mysql.mysql /data/  -R
  7. systemctl  restart  mysqld
复制代码

  1. help change master to;
  2. CHANGE MASTER TO
  3.   MASTER_HOST='192.168.240.12',
  4.   MASTER_USER='cxk',
  5.   MASTER_PASSWORD='Admin@123',
  6.   MASTER_PORT=3306,
  7.   MASTER_LOG_FILE='mysql-bin.000001',
  8.   MASTER_LOG_POS=154;
  9. show slave status\G;
  10. #查看设置的状态
  11. Seconds_Behind_Master: NULL    #目前数据差
  12. start slave;
  13. #开启线程,开启主从复制
  14. show slave status\G;
复制代码

(4)从节点2
  1. [root@localhost ~]#vim  /etc/my.cnf
  2. server-id=14
  3. log-bin=/data/mysql/mysql-bin
  4. #read only  #只读可加
  5. mkdir  -p  /data/mysql/binlog
  6. chown mysql.mysql /data/  -R
  7. systemctl  restart  mysqld
复制代码

  1. help change master to;
  2. CHANGE MASTER TO
  3.   MASTER_HOST='192.168.240.12',
  4.   MASTER_USER='cxk',
  5.   MASTER_PASSWORD='Admin@123',
  6.   MASTER_PORT=3306,
  7.   MASTER_LOG_FILE='mysql-bin.000001',
  8.   MASTER_LOG_POS=154;
  9. show slave status\G;
  10. #查看设置的状态
  11. Seconds_Behind_Master: NULL    #目前数据差
  12. start slave;
  13. #开启线程,开启主从复制
  14. show slave status\G;
复制代码
 

(5)测试

5.半同步复制

默认情况下,MySQL的复制功能是异步的,异步复制可以提供最佳的性能,主库把binlog日记发送给从库即结束,并不验证从库是否接收完毕。这意味着当主服务器或从服务器端发生故障时,有大概从服务器没有接收到主服务器发送过来的binlog日记,这就会造成主服务器和从服务器的数据不同等,甚至在规复时造成数据的丢失

实战测试
   主服务器:192.168.240.11
  从服务器1:192.168.240.12
  从服务器2:192.168.240.14
  (1)主服务器
  1. [root@localhost ~]#vim  /etc/my.cnf
  2. #修改文件
  3. [mysqld]
  4. server_id=11
  5. log-bin=/data/mysql/mysql-bin
  6. rpl_semi_sync_master_enabled=ON
  7. rpl_semi_sync_master_timeout=3000
  8. #修改此行,需要先安装semisync_master.so插件后,再重启,否则无法启动 开启半同步
  9. #设置3s内无法同步,也将返回成功信息给客户端
  10. [root@localhost ~]#mkdir /data/mysql/   -p
  11. #建立文件夹
  12. [root@localhost ~]#chown mysql.mysql /data/ -R
  13. #注意修改权限
  14. [root@localhost ~]#mysql -uroot -p123123
  15. mysql>INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so'; #永久安装插件
  16. mysql>UNINSTALL PLUGIN rpl_semi_sync_master ;#卸载
  17. mysql>SET GLOBAL rpl_semi_sync_master_enabled=1; #临时修改变量
  18. mysql>SET GLOBAL rpl_semi_sync_master_timeout = 3000;  #超时长1s,默认值为10s
  19. [root@localhost ~]#systemctl restart mysqld
  20. 进入数据库
  21. SHOW GLOBAL VARIABLES LIKE '%semi%';查看半同步状态
  22. grant replication slave on *.* to test@'192.168.91.%' identified by 'Admin@123';
复制代码

(2)从服务器1
  1. INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
  2. #安装插件
  3. [root@slave1 ~]#vim /etc/my.cnf
  4. [mysqld]
  5. server-id=12
  6. rpl_semi_sync_slave_enabled=ON #修改此行,需要先安装semisync_slave.so插件后,再重启,否则无法启动
复制代码
  1. help change master to;
  2. #查看帮助,复制修改
  3. CHANGE MASTER TO
  4.   MASTER_HOST='192.168.240.11',
  5.   MASTER_USER='test',
  6.   MASTER_PASSWORD='Admin@123',
  7.   MASTER_PORT=3306,
  8.   MASTER_LOG_FILE='mysql-bin.000003',
  9.   MASTER_LOG_POS=592;
  10. start slave;
  11. show global status like '%semi%';查看状态
复制代码


(3)从服务器2
  1. INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';
  2. #安装插件
  3. [root@slave1 ~]#vim /etc/my.cnf
  4. [mysqld]
  5. server-id=14
  6. rpl_semi_sync_slave_enabled=ON #修改此行,需要先安装semisync_slave.so插件后,再重启,否则无法启动
复制代码
  1. help change master to;
  2. #查看帮助,复制修改
  3. CHANGE MASTER TO
  4.   MASTER_HOST='192.168.240.11',
  5.   MASTER_USER='test',
  6.   MASTER_PASSWORD='Admin@123',
  7.   MASTER_PORT=3306,
  8.   MASTER_LOG_FILE='mysql-bin.000003',
  9.   MASTER_LOG_POS=592;
  10. start slave;
  11. show global status like '%semi%';查看状态
复制代码


(4)测试
当将从服务器2,关闭主从复制时
在主上创建cxk数据库时,主没有延迟,

当两台从服务器都关闭主从复制时
在主上创建cxk1数据库时,主有延迟3秒

当再次开启从服务器时
从服务器上数据同步
可以利用     show slave status\G;   #查看设置的状态
Seconds_Behind_Master: NULL    #目前数据差


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

张春

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表