• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Redis主从同步,读写分离设置 的相关操作

php 搞代码 3年前 (2022-01-22) 15次浏览 已收录 0个评论

本文介绍使用Redis的主从同步功能(master, slave),使程序实现读写分离,避免io瓶颈,提高数据读写效率。

Redis支持一个master服务器对多个slave服务器同步,同步使用发布/订阅机制。
1个master对多个slave,还可以进行分层,每个slave下可以再同步slave,扩展成树状结构。

Redis 主从同步设置

Redis默认的端口是6379,我们为了不影响原有Redis,使用新的端口

master 配置 redis_master.conf

port 6300requirepass 123456masterauth 123456daemonize yes

slave1 配置 redis_slave1.conf 设为master的slave

port 6301slaveof 127.0.0.1 6300requirepass 123456masterauth 123456daemonize yes

slave2 配置 redis_slave2.conf 设为master的slave

port 6302slaveof 127.0.0.1 6300requirepass 123456masterauth 123456daemonize yes

daemonize 表示后台启动。
requirepass 为主机认证密码。
masterauth 为从机访问主机验证密码,需要与主机的requirepass一致。
因后面需要演示主从切换,因此三组conf的验证密码都一致。

Redis 主从同步测试

依次启动master, slave1, slave2

redis-server redis_master.confredis-server redis_slave1.confredis-server redis_slave2.conf

执行后查看是否启动成功

ps aux|grep redisroot  1858  Ss  3:55  0:00.01 redis-server *:6302 root  1849  Ss  3:54  0:00.01 redis-server *:6301 root  1842  Ss  3:54  0:00.02 redis-server *:6300

进入master,设置key abc的值为123

redis-cli -p 6300127.0.0.1:6300> auth 123456OK127.0.0.1:6300> set abc 123OK127.0.0.1:6300> get abc"123"

分别进入slave1, slave2检查是否同步数据
slave1:

redis-cli -p 6301127.0.0.1:6301> auth 123456OK127.0.0.1:6301> get abc"123"127.0.0.1:6301>

slave2:

redis-cli -p 6302127.0.0.1:6302> auth 123456OK127.0.0.1:6302> get abc"123"127.0.0.1:6302>

进入master修改key abc的值为456

127.0.0.1:6300> set abc 456OK127.0.0.1:6300> get abc"456"

检查slave1, slave2是否同步
slave1:

127.0.0.1:6301> get abc"456"

slave2:

127.0.0.1:6302> get abc"456"

Redis主从切换

在运行过程中,如果master出现问题,我们可以通过设置,把另一台slave机自动设为master使用。这里主要用到Redis的sentinel功能来实现主从切换。

sentinel1.conf

port 26301sentinel monitor master 127.0.0.1 6300 2sentinel auth-pass master 123456logfile "/tmp/sentinel.log"daemonize yes

sentinel2.conf

port 26302sentinel monitor master 127.0.0.1 6300 2sentinel auth-pass master 123456logfile "/tmp/sentinel.log"daemonize yes

sentinel monitor master 127.0.0.1 6300 2 中的 2 表示有2个以上的sentinel服务检测到master失效,才会执行主从切换。

启动两个sentinel进程

redis-server sentinel1.conf --sentinelredis-server sentinel2.conf --sentinelps aux|grep redisroot  2643  Ss  4:28 0:00.02 redis-server *:26302 [sentinel]  root  2636  Ss  4:28 0:00.02 redis-server *:26301 [sentinel]

Redis日志可以看到,启动成功开始监控

Running mode=sentinel, port=26301.Sentinel ID is 3a23343948cd7f26662ccba1d01b92955311ef52+monitor master master 127.0.0.1 6300 quorum 2+slave slave 127.0.0.1:6301 127.0.0.1 6301 @ master 127.0.0.1 6300+slave slave 127.0.0.1:6302 127.0.0.1 6302 @ master 127.0.0.1 6300Running mode=sentinel, port=26302.Sentinel ID is ce0ee2af6b454205a3e475763945f505a10a7d6a+monitor master master 127.0.0.1 6300 quorum 2+slave slave 127.0.0.1:6301 127.0.0.1 6301 @ master 127.0.0.1 6300+slave slave 127.0.0.1:6302 127.0.0.1 6302 @ master 127.0.0.1 6300+sentinel sentinel 3a23343948cd7f26662ccba1d01b92955311ef52 127.0.0.1 26301 @ master 127.0.0.1 6300+sentinel sentinel ce0ee2af6b454205a3e475763945f505a10a7d6a 127.0.0.1 26302 @ master 127.0.0.1 6300

终止master,测试主从切换

kill master进程后,sentinel判断master失效,执行主从切换处理。

日志如下:

+failover-state-reconf-slaves master master 127.0.0.1 6300+slave-reconf-sent slave 127.0.0.1:6301 127.0.0.1 6301 @ master 127.0.0.1 6300+config-update-from sentinel 3a23343948cd7f26662ccba1d01b92955311ef52 127.0.0.1 26301 +switch-master master 127.0.0.1 6300 127.0.0.1 6302+slave slave 127.0.0.1:6301 127.0.0.1 6301 @ master 127.0.0.1 6302+slave slave 127.0.0.1:6300 127.0.0.1 6300 @ master 127.0.0.1 6302-odown master master 127.0.0.1 6300+slave-reconf-inprog slave 127.0.0.1:6301 127.0.0.1 6301 @ master 127.0.0.1 6300+slave-reconf-done slave 127.0.0.1:6301 127.0.0.1 6301 @ master 127.0.0.1 6300+failover-end master master 127.0.0.1 6300+switch-master master 127.0.0.1 6300 127.0.0.1 6302+convert-to-slave slave 127.0.0.1:6300 127.0.0.1 6300 @ master 127.0.0.1 6302

从日志可以看出,主从切换执行了以下操作:

1.将slave2切换为新的master,redis_slave2.conf 中的 slaveof 127.0.0.1 6300 被自动删除。

2.将redis_slave1.conf的 slaveof 127.0.0.1 6300 自动更新为 slaveof

。本文来源gao!%daima.com搞$代*!码网1

搞代gaodaima码 127.0.0.1 6302,使用slave2作为新的master。

3.原master重启动后,会作为slave使用,redis_master.conf会自动加入slaveof 127.0.0.1 6302。

原master重启后进行主从同步测试

原master更新key abc为888,因为现在已经是slave,所以更新失败。

127.0.0.1:6300> set abc 888(error) READONLY You can't write against a read only slave.

slave2 更新key abc为888

127.0.0.1:6302> set abc 888OK127.0.0.1:6302> get abc"888"

原master,slave1检查是否同步

原master

127.0.0.1:6300> get abc"888"

slave1

127.0.0.1:6301> get abc"888"

经检查,主从切换后,slave2作为新的master,其他服务器作为slave,可正常使用。

本文讲解了Redis主从同步,读写分离设置 的相关操作,更多相关内容亲关注搞代码

相关推荐:

介绍mysql重建表分区并保留数据的方法

PHP生成唯一RequestID类的相关内容

php json_encode不支持对象私有属性的解决方法


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Redis主从同步,读写分离设置 的相关操作
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址