目录
2.从服务器/etc/my.cnf配置,设置relay-log
MySQL主从复制作用
A.把读操作分流到从库上来减轻主库的压力
B.从库也可以作为备份库来使用
MySQL主从复制实现原理
MySQL主从复制是主库发送更新事件到从库,然后从库读取更新记录,并执行更新记录,最后使得从库的内容与主库保持一致。
环境准备
集群主机 | IP |
master | 192.168.30.10 |
slave | 192.168.30.11 |
MySQL安装
CentOS7环境下MySQL5.7源码安装https://blog.csdn.net/m0_69287945/article/details/125058766
master上操作:
查看进程
ps -ef |grep mysql
修改master上MySQL配置文件
vi /etc/my.cnf
#修改以下
log-bin = /data/mysql/3306/binlog/mysql-bin
server-id = 1
配置完以后重启数据库
重启脚本下载网址:
mysql启动停止重启脚本-Linux文档类资源-CSDN下载mysql启动停止重启脚本更多下载资源、学习资料请访问CSDN下载频道.https://download.csdn.net/download/m0_69287945/85509806下载以后重命名成mysql-3306.sh
./mysql-3306.sh restart
进入到MySQL检查log_bin是否开启
show variables like 'log_bin';
建立用于从库复制的账号test
GRANT REPLICATION SLAVE ON *.* TO 'test'@'192.168.30.%' IDENTIFIED BY 'admin';
#刷新
flush privileges;
在实际工作中,备份的时候是不让往库中写数据的,所以数据库要加锁,只能读。
FLUSH TABLES WITH READ LOCK;
记录主库log文件及其当前位置
SHOW MASTER STATUS;
记住File和Position的部分,从服务器会用到
备份数据
输入命令:
第一种,
mysqldump -uroot -p --all-databases > /tmp/db.sql
第二种,
mysqldump -uroot -p --all-databases --master-data=1 > /tmp/db.sql
把数据库传输到192.168.30.11上:
scp -r db.sql root@192.168.30.11:/tmp/
解锁 主库
数据备份完成后,就可以释放主库上的锁:
UNLOCK TABLES;
slave上操作:
vi /etc/my.cnf
#修改配置
server-id = 2
1.导入主库的数据
mysql -uroot -p < db.sql
2.从服务器/etc/my.cnf配置,设置relay-log
my.cnf文件中添加一行relay_log=relay-bin
relay-log = /data/mysql/3306/binlog/relay-bin
server-id = 2
3.重启数据库
重启脚本下载网址:
mysql启动停止重启脚本https://download.csdn.net/download/m0_69287945/85509806
下载以后重命名成mysql-3306.sh
./mysql-3306.sh restart
4.登录数据库
设置主从复制
CHANGE MASTER TO MASTER_HOST='192.168.30.10',MASTER_USER='test', MASTER_PASSWORD='admin', MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS= 201;
这个命令完成以下几个任务:
a.设置当前服务器为主服务器(192.168.30.10)的从库
b.提供当前数据库(从库)从主库复制数据时所需的用户名和密码,即上面的 GRANT REPLICATION SLAVE ON *.* TO 'test'@'192.168.30.%' IDENTIFIED BY 'admin';设置的
c.指定从库开始复制主库时需要使用的日志文件和文件位置,即上面主库执行SHOW MASTER STATUS;显示结果中的File和Position
5.开启主从复制
START SLAVE;
6.查看从库状态
show slave status\G
注意:结果中Slave_IO_Running和Slave_SQL_Running必须为Yes,如果不是,需要根据提示的错误修改。
验证主从复制
登录到主服务器的数据库上操作:
show databases;
在主数据库上做增删改操作,查看从数据库是否有变化。