首页 > 数据库 > Redis > 正文

Redis主从复制分步讲解使用

WBOY
发布: 2022-10-04 09:00:27
转载
2419 人浏览过

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于主从复制的相关内容,Redis因为其高性能和易用性在我们后端的服务中发挥了巨大的作用,并且很多重要功能的实现都会依赖redis,下面一起来看一下,希望对大家有帮助。

Redis主从复制分步讲解使用

推荐学习:Redis视频教程

主服务器(master)启用二进制日志 选择一个唯一的server-id 创建具有复制权限的用户

从服务器(slave)启用中继日志, 选择一个唯一的server-id 连接至主服务器,并开始复制

主库ip:192.168.235.130 端口:3306 从库ip:192.168.235.139 端口:3306

主库配置

(1)设置server-id值并开启binlog参数

[mysqld]
log_bin = mysql-bin
server_id = 130

重启数据库

(2)建立同步账号

creat user 'rep1'@'192.168.10.139' identified with mysql_native_password by 'Test@1234'#设置账户密码
grant replication slave on *.* to 'rep1'@'192.168.235.139';
grant replication slave on *.* to 'rep1'@'192.168.235.139';
show grants for 'rep1'@'192.168.235.139';

(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参数

#log_bin = /data/mysql/data/mysql-bin

server_id = 139

重启数据库

(2)还原从主库备份数据

cd /server/backup/
gzip -d mysql_bak.2022-09-22.sql.gz
mysql -uroot -p < mysql_bak.2022-09-22.sql
登录后复制

检查还原:

mysql -uroot -p -e &#39;show databases;&#39;
登录后复制

(3)设定从主库同步

mysql> change master to
    -> master_host=&#39;192.168.235.130&#39;,
    -> master_port=3306,
    -> master_user=&#39;rep1&#39;,
    -> master_password=&#39;Test@1234&#39;,
    -> master_log_file=&#39;mysql-bin.000006&#39;,
    -> 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中文网其他相关文章!

相关标签:
来源:jb51.net
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!