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
相关推荐
岁岁种桃花儿1 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
jiunian_cn2 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐3 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
Exquisite.4 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
知识分享小能手4 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
踩坑小念5 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
萧曵 丶5 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok6 小时前
MySQL的常用数据类型
数据库·mysql
曹牧6 小时前
Oracle 表闪回(Flashback Table)
数据库·oracle
J_liaty7 小时前
Redis 超详细入门教程:从零基础到实战精通
数据库·redis·缓存