一、理解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参数
[mysqld]
log_bin = mysql-bin
server_id = 120
重启数据库
(2)建立同步账号
mysql> grant replication slave on *.* to 'root'@'192.168.64.%' identified by
'123456';
mysql> show grants for 'root'@'192.168.64.%';
(3)锁表设置只读,为后面备份准备
mysql> flush tables with read lock;
mysql> show variables like '%timeout%';
(4)查看主库状态
查看主库状态,即当前日志文件名和二进制日志偏移量
mysql> show master status;
(5)备份数据库数据
mysqldump -uroot -p -A -B | gzip > /root/mysql/mysql-backup/mysql_bak.$(date +%F).sql.gz
(6)解锁
mysql> unlock tables;
(7)主库备份数据上传到从库
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参数
设置server-id值并关闭binlog参数
#log_bin = /data/mysql/data/mysql-bin
server_id = 130
(2)还原从主库备份数据
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)设定从主库同步
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)启动从库同步开关
mysql> start slave;
检查状态:
mysql> show slave status\G