redis集群sentinel哨兵模式的搭建与实际应用
参考资料:https://blog.csdn.net/men_wen/article/details/72724406
之前环境使用的keepalived+redis vip集群模式,现在我们服务切换到阿里云,尝试着使用一下哨兵的集群模式,期间遇到了很多坑,查了很多资料总算成功搭建完毕。
后期使用的稳定性还有待确认,暂时记录一下流程做备忘。
- 环境描述:阿里云主机3台(专有网络,开放6379端口,实现内网高可用性)搭建此环境至少三台服务器并且台数是基数,因为涉及到选举问题,我使用的云服务直接yum安装redis 和 redis-sentinel服务
- 192.168.1.66 (redis主)服务部署 redis主服务 redis-sentinel哨兵服务
- 192.168.1.67 (redis从)服务部署 redis主服务 redis-sentinel哨兵服务
- 192.168.1.68 (redis从)服务部署 redis主服务 redis-sentinel哨兵服务
准备工作:安装软件~
yum install redis redis-sentinel
cp /etc/redis-sentinel.conf /etc/back_redis-sentinel.conf
cp /etc/redis.conf /etc/back_redis.conf
一、配置Redis主服务
- redis主配置文件:(/etc/redis.conf)
bind 0.0.0.0
protected-mode no
port 6379
pidfile "/var/run/redis/redis.pid"
loglevel notice
logfile "/tmp/log/redis/redis.log"
databases 16
save 900 1
save 300 10
save 60 10000
dbfilename "dump.rdb"
dir "/tmp/lib/redis"
masterauth "11111111"
requirepass "11111111"
- redis从配置文件
bind 0.0.0.0
protected-mode no
port 6379
pidfile "/var/run/redis/redis.pid"
loglevel notice
logfile "/tmp/log/redis/redis.log"
databases 16
save 900 1
save 300 10
save 60 10000
dbfilename "dump.rdb"
dir "/tmp/lib/redis"
masterauth "11111111"
requirepass "11111111"
slaveof 192.168.1.66 6379
配置完毕后,启动服务测试是否能正常通信。如有报错请先处理不通的问题,部分错误可以见下方错误摘记
[root@itvcloud-yunwei Icloud]# redis-cli -h 172.17.189.87 #主备相互测试畅通,Pong为正常
172.17.189.87:6379>
172.17.189.87:6379>
172.17.189.87:6379> auth mypasswd
OK
172.17.189.87:6379> ping
PONG
二、配置哨兵模式
- redis-sentinel配置文件
// Sentinel节点的端口
port 26379
dir /var/redis/data/
logfile "26379.log" // 当前Sentinel节点监控 192.168.1.66:6379 这个主节点
// 2代表判断主节点失败至少需要2个Sentinel节点节点同意
// mymaster是主节点的别名
sentinel monitor mymaster 192.168.1.66 6379 2 //每个Sentinel节点都要定期PING命令来判断Redis数据节点和其余Sentinel节点是否可达,如果超过30000毫秒且没有回复,则判定不可达
sentinel down-after-milliseconds mymaster 30000 //当Sentinel节点集合对主节点故障判定达成一致时,Sentinel领导者节点会做故障转移操作,选出新的主节点,原来的从节点会向新的主节点发起复制操作,限制每次向新的主节点发起复制操作的从节点个数为1
sentinel parallel-syncs mymaster 1 //故障转移超时时间为180000毫秒
sentinel failover-timeout mymaster 180000
- 启动服务后redis-sentinel配置文件会变更为
port 26379
protected-mode no
bind 0.0.0.0
sentinel myid 2c3a6184def1f66f8e97f864e17257aa29c8bbea
sentinel auth-pass mymaster 11111111
sentinel config-epoch mymaster 229
sentinel leader-epoch mymaster 229
logfile "/var/log/redis/sentinel.log"
daemonize yes
pidfile "/var/run/redis/sentinel.pid"
# Generated by CONFIG REWRITE
dir "/tmp"
有几点需要注意:
1.遇到的问题是哨兵模式检测主服务一直是odown状态,出现故障后也无法自动切换,检测不到主服务状态
解决办法:redis-sentinel.conf 配置protected-mode no,此选项会影响哨兵模式之间的通信,关闭安全模式即可,或者增加bind 0.0.0.0
2.密码添加注意需要在redis.conf配置密码,在redis-sentinel.conf理也需要配置密码,否则会影响切换
3.(error) MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error. 这个错误是没有给redis存储dump文件目录的权限, chown -R redis.redis /var/lib/redis
粗略记录仅供自己做备忘。
4.相互之间端口都互通,ping状态为pong,客户端状态为master_link_status:down ,此状态下数据无法著丛复制,查看master 报错 Can't save in background: fork: Cannot allocate memory,
解决办法: vi /etc/sysctl.conf 添加 vm.overcommit_memory = 1 ; sysctl -p使配置生效 原因可以参考:https://blog.csdn.net/zqz_zqz/article/details/53384854
redis集群sentinel哨兵模式的搭建与实际应用的更多相关文章
- (六) Docker 部署 Redis 高可用集群 (sentinel 哨兵模式)
参考并感谢 官方文档 https://hub.docker.com/_/redis GitHub https://github.com/antirez/redis happyJared https:/ ...
- redis集群之哨兵模式【原】
redis集群之哨兵(sentinel)模式 哨兵模式理想状态 需要>=3个redis服务,>=3个redis哨兵,每个redis服务搭配一个哨兵. 本例以3个redis服务为例: 一开始 ...
- Redis集群--Redis集群之哨兵模式
echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 搭建R ...
- docker 搭建 redis 集群(哨兵模式)
文件结构 1. redis-sentinel 1-1. docker-compose.yml 1-2. sentinel 1-2-1 docker-compose.yml 1-2-2 sentinel ...
- Spring Boot集成Redis集群(Cluster模式)
目录 集成jedis 引入依赖 配置绑定 注册 获取redis客户端 使用 验证 集成spring-data-redis 引入依赖 配置绑定 注册 获取redis客户端 使用 验证 异常处理 同样的, ...
- Windows系统搭建Redis集群三种模式(零坑、最新版)
目录 主从复制 修改配置文件 启动各节点 验证 哨兵模式 修改配置文件 启动实例 验证 集群模式 修改配置文件 启动实例 验证 主从复制 新建以下三个目录,用来部署一主二从 redis 的安装在另外一 ...
- redis(5)--redis集群之哨兵机制
哨兵机制 在前面讲的master/slave模式,在一个典型的一主多从的系统中,slave在整个体系中起到了数据冗余备份和读写分离的作用.当master遇到异常终端后,需要从slave中选举一个新的m ...
- Redis集群与分布式介绍以及搭建Redis-Cluster
1 Redis集群 1.1 什么是集群 集群就是很多服务器组成的一个网络.指的是将多台服务器集中在一起,实现同一业务. 1.2 为什么要集群 一台服务器不能满足开发需要的时候,需要多台服务器来支持.这 ...
- Redis集群主备模式部署
网上有非常多用Ruby安装Redis-cluster的文章.可是在实际环境下不想安装Ruby,所以本文主要介绍了用Redis命令部署Redis集群.而且为集群中每个master实例添加一个slave实 ...
随机推荐
- thinkphp5 rbac权限
thinkphp 5 rbac权限 一 先创建一个数据库; 例如:创建一个test数据库;然后创建3个 表分别为:test_admin (管理员表), test_role,test_auth. 这个是 ...
- 一、PHP基础-安装PHP集成环境
目录 PHP运行集成环境下载 phpStudy集成环境安装 XAMPP集成环境安装 WampServer环境安装 作者:吴耀田 个人博客:http://www.cnblogs.com/isaacwy ...
- 3D立方体
效果图 主要用到的3D属性 1.保留子元素的3d属性:transform-style:preserve-3d; 2.2D变形属性: ①transform:translate()平移,分X轴,Y轴,Z轴 ...
- 帝国cms全文搜索 增加自定义字段搜索
帝国cms全站搜索功能只能调出固定的几个字段,如果想搜索其他字段的值,这时我们应该怎么办呢?开拓族网站有这个需求,所以研究了一下帝国的全站搜索,后来发现在/e/sch/index.php中可以直接对数 ...
- 【laravel】passport的scope作用域
1.根据作用域生成token $user->createToken($request->name,['test1'])->accessToken; 2.注册中间件 'scopes' ...
- 迪米特法则(LoD)
如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用.如果其中一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用.其根本思想是类之间的松耦合. 类之间的耦合越弱,越有利于 ...
- linux使用logrotate工具管理日志轮替
对于Linux系统安全来说,日志文件是极其重要的工具.logrotate程序是一个日志文件管理工具.用于分割日志文件,删除旧的日志文件,并创建新的日志文件,起到"转储"作用.可以节 ...
- Python学习 :迭代器&生成器
列表生成式 列表生成式的操作顺序: 1.先依次来读取元素 for x 2.对元素进行操作 x*x 3.赋予变量 Eg.列表生成式方式一 a = [x*x for x in range(10)] pri ...
- 第7天 Java基础语法
第7天 Java基础语法 今日内容介绍 循环练习 数组方法练习 循环练习 编写程序求 1+3+5+7+……+99 的和值. 题目分析: 通过观察发现,本题目要实现的奇数(范围1-100之间)的累加和. ...
- Qt 本地化(翻译)
Qt 本地化(翻译) 翻译流程大致是这样的:首先源代码产生 ts 文件,然后送给 Qt Linguist(Qt 语言家)这个 Qt 自带的小工具进行处理产生 qm 翻译文件,最后源代码里加载这个 qm ...