【资料图】
推荐学习:Redis视频教程
主服务器(master)启用二进制日志 选择一个唯一的server-id 创建具有复制权限的用户
从服务器(slave)启用中继日志, 选择一个唯一的server-id 连接至主服务器,并开始复制
主库ip:192.168.235.130 端口:3306 从库ip:192.168.235.139 端口:3306
主库配置
(1)设置server-id值并开启binlog参数
重启数据库
(2)建立同步账号
(3)锁表设置只读
为后面备份准备,注意生产环境要提前申请停机时间;
mysql>flush tables with read lock;
登录后复制
提示:如果超过设置时间不操作会自动解锁。
mysql>show variables like "%timeout%";
登录后复制
测试锁表后是否可以创建数据库
4)查看主库状态 查看主库状态,即当前日志文件名和二进制日志偏移量
mysql>show master status;
登录后复制
记住file和position,方便slave后续连接。
(5)备份数据库数据
mysqldump -uroot -p -A -B |gzip >mysql_bak.$(date +%F).sql.gz
登录后复制
(6)解锁
mysql>unlock tables;
登录后复制
(7)主库备份数据上传到从库
scp /server/backup/mysql_bak.2022-09-22.sql.gz 192.168.235.139:/root/hh
登录后复制
从库上设置
(1)设置server-id值并关闭binlog参数
重启数据库
(2)还原从主库备份数据
cd /server/backup/gzip -d mysql_bak.2022-09-22.sql.gzmysql -uroot -p < mysql_bak.2022-09-22.sql
登录后复制
检查还原:
mysql -uroot -p -e "show databases;"
登录后复制
(3)设定从主库同步
mysql>change master to ->master_host="192.168.235.130", ->master_port=3306, ->master_user="rep1", ->master_password="Test@1234", ->master_log_file="mysql-bin.000006", ->master_log_pos=157;
登录后复制
(4)启动从库同步开关
mysql>start slave;
登录后复制
检查状态:
mysql>show slave status\G
登录后复制
主备复制功能达成。
下面进行测试:
在192.168.235.130(主)上执行:
create databses data;
新建数据库
从虚拟机上也建好了data文件,实现了Mysql的主从复制。
推荐学习:Redis视频教程
以上就是Redis主从复制分步讲解使用的详细内容,更多请关注php中文网其它相关文章!