MySQL 主从复制的认识 2023.07.23

一、理解MySQL主从复制原理

1、概念:主从复制是用来建立一个和 主数据库完全一样的数据库环境称为从数据库;主数据库一般是准实时的业务数据库。

2、作用:灾备、数据分布、负载平衡、读写分离、提高并发能力

3、原理图

4、具体步骤

(1) Master的更新事件(update、insert、delete)会按照顺序写入bin-log中。当Slave连接到Master的后,Master机器会为Slave开启binlog dump线程,该线程会去读取bin-log日志。
(2) Slave连接到Master后,Slave库有一个I/O线程 通过请求binlog dump thread读取bin-log日志,然后写入从库的relay log日志中。
(3) Slave还有一个 SQL线程,实时监控 relay-log日志内容是否有更新,解析文件中的SQL语句,在Slave数据库中去执行。

二、完成MySQL主从复制

1、主库的配置

(1)设置server-id值并开启binlog参数
bash 复制代码
[mysqld]
log_bin = mysql-bin
server_id = 120

重启数据库
(2)建立同步账号
bash 复制代码
mysql> grant replication slave on *.* to 'root'@'192.168.64.%' identified by
'123456';

mysql> show grants for 'root'@'192.168.64.%';
(3)锁表设置只读,为后面备份准备
bash 复制代码
mysql> flush tables with read lock;

mysql> show variables like '%timeout%';
(4)查看主库状态
bash 复制代码
查看主库状态,即当前日志文件名和二进制日志偏移量
mysql> show master status;
(5)备份数据库数据
bash 复制代码
mysqldump -uroot -p -A -B | gzip > /root/mysql/mysql-backup/mysql_bak.$(date +%F).sql.gz
(6)解锁
bash 复制代码
mysql> unlock tables;
(7)主库备份数据上传到从库
bash 复制代码
scp /root/mysql/mysql-backup/mysql_bak.2023-07-23.sql.gz 192.168.64.4:/root/mysql/mysql-backup/

2、从库设置

(1)设置server-id值并关闭binlog参数
bash 复制代码
设置server-id值并关闭binlog参数
#log_bin = /data/mysql/data/mysql-bin
server_id = 130
(2)还原从主库备份数据
bash 复制代码
cd /root/mysql/mysql-backup/

gzip -d mysql_bak.2023-07-23.sql.gz

mysql -uroot -p < mysql_bak.22023-07-23.sql

检查还原
mysql -uroot -p -e 'show databases;'
(3)设定从主库同步
bash 复制代码
mysql> change master to
MASTER_HOST='192.168.64.4',
MASTER_PORT=3306,
MASTER_USER='rep',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000003',
MASTER_LOG_POS=329;
(4)启动从库同步开关
bash 复制代码
mysql> start slave;

检查状态:
mysql> show slave status\G
相关推荐
rannn_1116 分钟前
【SQL题解】力扣高频 SQL 50题|DAY2+3
数据库·后端·sql·leetcode
l1t10 分钟前
DeepSeek对Oracle 数据库新特性 SQL 宏的总结
数据库·人工智能·sql·oracle
是垚不是土10 分钟前
MySQL8.0数据库GTID主从同步方案
android·网络·数据库·安全·adb
cnxy18811 分钟前
MySQL地理空间数据完整使用指南
android·数据库·mysql
鲸说MySQL12 分钟前
【MySQL事务(一)事务的操作流程】
数据库·mysql
程序边界12 分钟前
10年Oracle运维转战国产数据库:迁移路上的“坑”与“光”
运维·数据库·oracle
一个天蝎座 白勺 程序猿14 分钟前
Apache IoTDB(12):深度解析时序数据聚合的GROUP BY与HAVING子句
数据库·sql·apache·iotdb
abap帅哥19 分钟前
SAP MIRO/MIR4付款条件消失 :设计逻辑、根本原因与终极解决方案
数据库·后端·sap·abap·erp
不穿格子的程序员21 分钟前
Redis篇9——Redis深度剖析:
数据库·redis·多线程·事务回滚·ap·cp
今晚务必早点睡24 分钟前
Redis——快速入门第五课:Redis 常见坑 & 面试高频问题
数据库·redis·面试