阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Redis复制+Sentinel搭建详解

405次阅读
没有评论

共计 7675 个字符,预计需要花费 20 分钟才能阅读完成。

1:实验环境
测试环境两台:
master:172.16.16.34
slave:172.16.16.35
redis 版本:redis3.2
要搭建的环境是,redis 简单主从复制
2:安装 redis
tar xzf redis-3.2.8.tar.gz
cd redis-3.2.8
yum install gcc
make

注意我们使用的是 redis3.2.8 的版本,这是目前最稳定也是最新的 redis 版本了。下面我们看一下简单配置

3:配置启动 redis
先看一下我主库的配置文件(172.16.16.34)
#bind 127.0.0.1    # 绑定的主机地址
protected-mode no  # 是否开启保护模式,开启该参数后,redis 只会本地进行访问
port 6379
timeout 300  # 当客户端闲置多长时间后关闭连接

daemonize yes  # 是否以守护进程的模式运行
pidfile /home/redis/tmp/redis_6379.pid

loglevel notice       # 日志级别,最好是 warning
logfile /home/redis/log/redis_6379.log

databases 16
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes   # 在出现错误的时候,是否要停止保存
rdbcompression yes   # 使用压缩 rdb 文件
rdbchecksum yes     # 是否校验 rdb 文件的名称
dbfilename dump.rdb
dir /home/redis/data     # 数据库目录,数据库的写入会在这个目录

slave-serve-stale-data yes      #主从失去联系以后,继续相应客户端的请求
#slave-read-only yes     # yes 开启从库只读
repl-diskless-sync no   # 是否使用 socket 方式复制数据,采用 disk 的方式
repl-diskless-sync-delay 5      # diskless 复制的延迟时间,默认值是 5,可以不设置
repl-disable-tcp-nodelay no    #此设置可减少延迟
slave-priority 100      # 设置优先级,最低的优先级会优先称为主节点

appendonly no   #不使用 appendonly 来进行持久化操作
#appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no    #
auto-aof-rewrite-percentage 100     #开始重写日志
auto-aof-rewrite-min-size 64mb

lua-time-limit 5000     #最长时间设置,默认为毫秒
slowlog-log-slower-than 10000   #慢查询的时间
slowlog-max-len 128

latency-monitor-threshold 0     #关闭监视器
requirepass maxiangqianredis
然后启动主库的 redis:
/home/maxiangqian/redis-3.2.8/src/redis-server /home/redis/redis.conf
这里需要注意的一点就是后面的注释都要去掉,因为 redis 会继续往后读取,# 并不适用除了首行以上。
下面配置从库 redis 并且启动从库(172.16.16.35):
port 6379
timeout 300 

daemonize yes  
pidfile /home/redis/tmp/redis_6379.pid

loglevel notice      
logfile /home/redis/log/redis_6379.log

databases 16
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes  
rdbcompression yes 
rdbchecksum yes    
dbfilename dump.rdb
dir /home/redis/data 

slave-serve-stale-data yes    
#slave-read-only yes     # yes 开启从库只读
repl-diskless-sync no  
repl-diskless-sync-delay 5    
repl-disable-tcp-nodelay no  
slave-priority 100     

appendonly no  
#appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no  
auto-aof-rewrite-percentage 100     
auto-aof-rewrite-min-size 64mb

lua-time-limit 5000    
slowlog-log-slower-than 10000  
slowlog-max-len 128

latency-monitor-threshold 0   
requirepass maxiangqianredis
slaveof 172.16.16.34 6379
masterauth maxiangqianredis
启动 redis 从库
/home/maxiangqian/redis-3.2.8/src/redis-server /home/redis/redis.conf
我们注意就是从库的配置的话比主库是多了最后两行,指定主库,指定主库的认证方式
另外我们也可以在从库加上 slave-read-only yes 参数来控制从库是否是只能为只读。
然后同样方法启动一个 6380 的从库
4:查看 redis 主从同步是否成功
主库执行如下操作

[root@localhost redis]# /home/maxiangqian/redis-3.2.8/src/redis-cli 
127.0.0.1:6379> AUTH maxiangqianredis
OK
127.0.0.1:6379> set name maxiangqian
OK
从库验证是否配置成功:

[root@mxqmongodb2 redis]# /home/maxiangqian/redis-3.2.8/src/redis-cli 
127.0.0.1:6379> get name
127.0.0.1:6379> AUTH maxiangqianredis
OK
127.0.0.1:6379> get name
"maxiangqian"
我们可以看到,slave 已经同步了 master 的数据。简单的主从搭建也就完成了。
5:现在主从配置成功了,但是万一主库 down 掉,我们是并不能主动进行切换的,所以我们要做高可用方案,我们使用 redis 官方推荐的 Redis-Sentinel,关于这个介绍,可以网上搜下,介绍还是很多的。不过我们还是简单介绍一下 Redis-Sentinel 吧。
Redis-Sentinel 的主要作用:
(1)监控(Monitoring):Sentinel 会不断地检查你的主服务器和从服务器是否运作正常。
(2)提醒(Notification):当被监控的某个 Redis 服务器出现问题时,Sentinel 可以通过 API 向管理员或者其他应用程序发送通知。
(3)自动故障迁移(Automatic failover):当一个主服务器不能正常工作时,Sentinel 会开始一次自动故障迁移操作,它会将失效主服务器的其中一个从服务器升级为新的主服务器,并让失效主服务器的其他从服务器改为复制新的主服务器;当客户端试图连接失效的主服务器时,集群也会向客户端返回新主服务器的地址,使得集群可以使用新主服务器代替失效服务器。
我们看到了 Redis-Sentinel 的功能以后就看一下怎么启动 Redis-Sentinel,官方给的是有两种启动方式:
edis-sentinel  /path/to/sentinel.conf
redis-server /path/to/sentinel.conf --sentinel
两种启动方式都是可以的。下面看一下我们要怎么去配置这个 Redis-Sentinel:
最基本的配置如下:

port  26379
logfile "/home/Sentinel/log/sentinel_263797.log"
daemonize yes
sentinel monitor localhost 172.16.16.34 6379 2
sentinel down-after-milliseconds localhost 60000
sentinel failover-timeout localhost 180000
sentinel parallel-syncs localhost 1
sentinel auth-pass localhost maxiangqianredis
#sentinel notification-script <master-name> <script-path>
最后一行代码主要是用来发生切换之后执行的一个自定义脚本:如发邮件、vip 切换等。比较方便我们操作。再看一下 Redis-Sentinel 的基本操作
PING:返回 PONG。SENTINEL masters:列出所有被监视的主服务器,以及这些主服务器的当前状态。SENTINEL slaves:列出给定主服务器的所有从服务器,以及这些从服务器的当前状态。SENTINEL get-master-addr-by-name:返回给定名字的主服务器的 IP 地址和端口号。如果这个主服务器正在执行故障转移操作,或者针对这个主服务器的故障转移操作已经完成,那么这个命令返回新的主服务器的 IP 地址和端口号。SENTINEL reset:重置所有名字和给定模式 pattern 相匹配的主服务器。pattern 参数是一个 Glob 风格的模式。重置操作清楚主服务器目前的所有状态,包括正在执行中的故障转移,并移除目前已经发现和关联的,主服务器的所有从服务器和 Sentinel。SENTINEL failover:当主服务器失效时,在不询问其他 Sentinel 意见的情况下,强制开始一次自动故障迁移(不过发起故障转移的 Sentinel 会向其他 Sentinel 发送一个新的配置,其他 Sentinel 会根据这个配置进行相应的更新)。
下面开始配置 Redis-Sentinel 的监控:
[root@mxqmongodb2 home]# mkdir Sentinel
[root@mxqmongodb2 home]# cd Sentinel/
[root@mxqmongodb2 Sentinel]# mkdir data log tmp
启动:/home/maxiangqian/redis-3.2.8/src/redis-server /home/Sentinel/sentinel.conf  --sentinel
查看一下啊主库信息:
SENTINEL masters
SENTINEL slaves localhost
可以看到,master 信息和两个从库的信息已经打印出来了。已经检测成功了。
同样配置文件在 35 上在启动一个 sentinel。
 
127.0.0.1:26379> info sentinel 
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=localhost,status=ok,address=172.16.16.34:6379,slaves=2,sentinels=4
 
我们已经看到已经启动了主从以及 sentinel HA,下面我们测试一下故障转移
6:测试故障转移
 
127.0.0.1:26379> sentinel failover localhost
OK
下面我们看一下 redis 强制故障转移以后的信息
127.0.0.1:26379> info sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=localhost,status=ok,address=172.16.16.35:6379,slaves=2,sentinels=2
可以看到现在 35:6379 已经转移称为了主节点。
我们进入我们的 sentinel 的日志看一下 failover 的一个过程
29042:X 28 Apr 10:55:14.340 # +try-failover master localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:14.394 # +vote-for-leader 51fc16eb8e0bf950a3f3ada8c1eb9d70145c9ffb 1
29042:X 28 Apr 10:55:14.395 # +elected-leader master localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:14.395 # +failover-state-select-slave master localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:14.457 # +selected-slave slave 172.16.16.35:6379 172.16.16.35 6379 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:14.457 * +failover-state-send-slaveof-noone slave 172.16.16.35:6379 172.16.16.35 6379 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:14.510 * +failover-state-wait-promotion slave 172.16.16.35:6379 172.16.16.35 6379 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:15.436 # +promoted-slave slave 172.16.16.35:6379 172.16.16.35 6379 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:15.436 # +failover-state-reconf-slaves master localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:15.507 * +slave-reconf-sent slave 172.16.16.35:6380 172.16.16.35 6380 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:16.465 * +slave-reconf-inprog slave 172.16.16.35:6380 172.16.16.35 6380 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:16.466 * +slave-reconf-done slave 172.16.16.35:6380 172.16.16.35 6380 @ localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:16.540 # +failover-end master localhost 172.16.16.34 6379
29042:X 28 Apr 10:55:16.540 # +switch-master localhost 172.16.16.34 6379 172.16.16.35 6379
29042:X 28 Apr 10:55:16.541 * +slave slave 172.16.16.35:6380 172.16.16.35 6380 @ localhost 172.16.16.35 6379
29042:X 28 Apr 10:55:16.541 * +slave slave 172.16.16.34:6379 172.16.16.34 6379 @ localhost 172.16.16.35 6379
 
过程如下:
(1)尝试 DOWN 掉主节点 redis172.16.16.34 6379
(2)选取一个从节点作为 DOWN 后的主节点 172.16.16.35:6379
(3)重写配置文件
查看配置文件发现,主库重新指定为
slaveof 172.16.16.35 6379
(4)主库 DOWN 结束,新节点 172.16.16.35:6379 成为了主节点,然后另外两个节点称为主节点的从节点。

下面关于 Redis 的文章您也可能喜欢,不妨参考下:

Ubuntu 14.04 下 Redis 安装及简单测试 http://www.linuxidc.com/Linux/2014-05/101544.htm

Redis 主从复制基本配置 http://www.linuxidc.com/Linux/2015-03/115610.htm

CentOS 7 下 Redis 的安装与配置 http://www.linuxidc.com/Linux/2017-02/140363.htm

Ubuntu 14.04 安装 Redis 与简单配置 http://www.linuxidc.com/Linux/2017-01/139075.htm

Ubuntu 16.04 环境中安装 PHP7.0 Redis 扩展 http://www.linuxidc.com/Linux/2016-09/135631.htm

Redis 单机 & 集群离线安装部署 http://www.linuxidc.com/Linux/2017-03/141403.htm

Redis 集群搭建与管理  http://www.linuxidc.com/Linux/2017-05/144178.htm

CentOS 7.0 安装 Redis 3.2.1 详细过程和使用常见问题 http://www.linuxidc.com/Linux/2016-09/135071.htm

Ubuntu 16.04 环境中安装 PHP7.0 Redis 扩展 http://www.linuxidc.com/Linux/2016-09/135631.htm

Ubuntu 15.10 下 Redis 集群部署文档 http://www.linuxidc.com/Linux/2016-06/132340.htm

Redis 实战 中文 PDF http://www.linuxidc.com/Linux/2016-04/129932.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-06/144618.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计7675字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7800536
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
【开源神器】微信公众号内容单篇、批量下载软件

【开源神器】微信公众号内容单篇、批量下载软件

【开源神器】微信公众号内容单篇、批量下载软件 大家好,我是星哥,很多人都希望能高效地保存微信公众号的文章,用于...
升级自动部署更新SSL证书系统、申请godaddy的APIKEY

升级自动部署更新SSL证书系统、申请godaddy的APIKEY

升级自动部署更新 SSL 证书系统、申请 godaddy 的 APIKEY 公司之前花钱购买的 ssl 证书快...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...
240 元左右!五盘位 NAS主机,7 代U硬解4K稳如狗,拓展性碾压同价位

240 元左右!五盘位 NAS主机,7 代U硬解4K稳如狗,拓展性碾压同价位

  240 元左右!五盘位 NAS 主机,7 代 U 硬解 4K 稳如狗,拓展性碾压同价位 在 NA...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
【开源神器】微信公众号内容单篇、批量下载软件

【开源神器】微信公众号内容单篇、批量下载软件

【开源神器】微信公众号内容单篇、批量下载软件 大家好,我是星哥,很多人都希望能高效地保存微信公众号的文章,用于...
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换...
星哥带你玩飞牛NAS-7:手把手教你免费内网穿透-Cloudflare tunnel

星哥带你玩飞牛NAS-7:手把手教你免费内网穿透-Cloudflare tunnel

星哥带你玩飞牛 NAS-7:手把手教你免费内网穿透 -Cloudflare tunnel 前言 大家好,我是星...