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 小时前
使用 IntelliJ IDEA 结合 DBeaver 连接 MySQL 数据库并实现数据增删查改的详细步骤:
数据库·mysql·intellij-idea
b78gb3 小时前
电商秒杀系统设计 Java+MySQL实现高并发库存管理与订单处理
java·开发语言·mysql
奥尔特星云大使3 小时前
CentOS 7 安装 MySQL 8
mysql·centos·mysql 8
lang201509284 小时前
MySQL FIPS模式:安全合规全解析
mysql
一只叫煤球的猫6 小时前
建了索引还是慢?索引失效原因有哪些?这10个坑你踩了几个
后端·mysql·性能优化
呼哧呼哧.6 小时前
Spring的核心思想与注解
数据库·sql·spring
21号 17 小时前
9.Redis 集群(重在理解)
数据库·redis·算法
爬山算法7 小时前
Redis(73)如何处理Redis分布式锁的死锁问题?
数据库·redis·分布式
嘗_7 小时前
sql特训
数据库·sql
wan5555cn8 小时前
周末之美:慢下来,拥抱生活的温柔
数据库