docker------redis容器下的sentinel哨兵模式 - Go语言中文社区

docker------redis容器下的sentinel哨兵模式


目录

简介

配置主从redis

将从redis配置成sentinel哨兵

测试


简介

Redis Sentinel即采用Sentinel得方案开启哨兵模式,在此模式下主redis服务崩溃其余从redis(哨兵)会随机选出一个转为主库,这样既可以保证安全性可靠性以实现高可用

为了方便我们采用docker容器来实现Sentinel哨兵

配置主从redis

首先拉取redis得镜像

$ docker pull redis

然后开动三个容器并开启端口映射这里我们用6379 6380 6381 三个端口

$ docker run --name redis-master -p 6379:6379 -d redis

$ docker run --name redis-slave1 -p 6380:6379 -d redis

$ docker run --name redis-slave2 -p 6381:6379 -d redis

然后查看主redis容器得内网IP地址

$ docker inspect redis-master

 

这里可以看到主redis容器得内网ip地址为172.17.0.2

一次查看其余内网地址为

172.17.0.3    172.17.0.4

然后进去从redis容器,打开redis客户端对redis进行配置

$ docker exec -it redis-slave1 /bin/bash

$ redis-cli

然后设置从redis容器的主redis容器目标为172.17.0.2 端口号为映射的端口号我们主容器映射的是6379

$ slaveof 172.17.0.2 6379

当显示OK时查看当前redis的角色和配置信息等

$ info replication

在这里可以看到配置信息无误,然后我们按同样的方法配置第二台从服务器

将从redis配置成sentinel哨兵

在各个从redis容器中的根目录

创建文件 sentinel.conf来设定哨兵

$ vim sentinel.conf

如果出现command not found错误按顺序运行以下命令这个错误是因为我们在docker的容器中是默认没有vim这个命令的这时候我们需要安装它

$ apt-get update

$ apt-get install vim

在 sentinel.conf文件中将主redis容器配置进去

sentinel monitor redis-master 172.17.0.2 6379 1

启动哨兵

$ redis-sentinel /sentinel.conf

在这里可以看到一些配置信息

 

同样的一次配置第二个从redis容器并启动,不过我们可以多开几个窗口方便测试和配置

测试

将主redis容器停止,然后进入任意一个从从redis容器并查看状态最后可以看到从redis容器的role变成了master

$ docker stop redis-master

//在从容器中

$ redis-cli

Info replication

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/xrMrwhile/article/details/103722111
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-04-19 13:29:26
  • 阅读 ( 1128 )
  • 分类:Redis

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢