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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值