基于Docker实现Redis主从+哨兵搭建的示例实践

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/
目录1.拉取镜像2. 编写主 从配置文件2.1 创建/home/redis/redis_conf目录:2.2 编写主配置文件2.3 编写从配置文件2.4  编写从配置文件3 编写sentinel配置文件3.1创建哨兵配置文件        3.2编写哨兵配置文件      4  启动主节点容器4.1启动主节点容器4.2 启动从节点容器5 存在的问题:6、分别启动每个  docker容器里面的哨兵6.1进入主节点容器6.2查看文件6.3启动主哨兵服务6.4 启动两个从哨兵服务6.5进入主哨兵6.6查看哨兵状态6.7退出哨兵6.8退出容器

说明:在一台服务器上搭建redis一主二从三哨兵

1.拉取镜像

docker pull redis:4

基于Docker实现Redis主从+哨兵搭建的示例实践插图

2. 编写主 从配置文件

2.1 创建/home/redis/redis_conf目录:

基于Docker实现Redis主从+哨兵搭建的示例实践插图1

2.2 编写主配置文件

#vi redis-master.conf

port 6379 #服务端口 bind 0.0.0.0 #任何服务器都可连接 logfile “redis.log” #日志文件名 dir /data #data为等会开启docker容器里面的目录 appendonly yes #是否持久化

2.3 编写从配置文件

#vi redis-slave-1.conf

port 6380 bind 0.0.0.0 logfile “redis.log” dir /data daemonize no appendonly yes slaveof 192.168.17.33 6379 slave-read-only no

2.4  编写从配置文件

#vi redis-slave-2.conf

port 6381 bind 0.0.0.0 logfile “redis.log” dir /data daemonize no #关闭redis自我保护 appendonly yes #开启redis持久化 slaveof 192.168.17.33 6379 #给该从节点指定隶属于的主节点 slave-read-only no #如果没有这一行从节点不能写入数据只能读取数据

3 编写sentinel配置文件

3.1创建哨兵配置文件        

touch sentinel.conf

3.2编写哨兵配置文件      

3.2.1   vim sentinel.conf

port 26379 dir “/data” logfile “sentinel.log” daemonize yes sentinel monitor mymaster 192.168.17.33 6379 2 #这里是哨兵的关键 mymaster:哨兵集群的名称 配置主节点的ip和端口 ,后面的数字2表示当哨兵集群当中有两个哨兵没有检测到主节点的心跳的时候表明主节点挂掉,开始推选新的主节点。(这里我们的哨兵 集群总共有三个哨兵)

3.2.2  vim sentinel2.conf

port 26380 dir “/data” logfile “sentinel.log” daemonize yes sentinel monitor mymaster 192.168.17.33 6379 2

3.2.3  vim sentinel3.conf

port 26381 dir “/data” logfile “sentinel.log” daemonize yes sentinel monitor mymaster 192.168.17.33 6379 2

4  启动主节点容器

4.1启动主节点容器

4.1.1 启动容器

docker run -d -p 6379:6379 -p 26379:26379 -v /home/redis/redis_conf/redis-master.conf:/data/redis.conf -v /home/redis/redis_conf/sentinel.conf:/data/sentinel.conf –name redis-master redis:4 redis-server redis.conf

4.1.2 进入容器

docker exec -it redis-master /bin/bash

4.1.3 进入redis客户端

(默认是进入 6379 端口的 redis 。还有我们在启动容器的时候已经顺便将 redi服务端启动起来了:redis-server redis.conf,所以进入容器不用启动redis 服务了,直接可以进入客户端了。 redis-cli

4.1.4查看redis信息,如果是主节点

role 将会为 master 。

info replication

4.1.5退出redis-cli

exit

4.1.6退出redis-master 容器

exit

4.2 启动从节点容器

(两个从节点容器是一样的启动方式,只修改对应的路径,端口映射,名称等,最后面的redis.conf对应的是容器内映射的redis.conf),这里只写出启动一个从节点

的命令,自己启动第二个从节点。

4.2.1启动容器,并同时用容器内的redis.conf启动redis

#启动redis-slave-1容器 同时启动redis-server docker run -d -p 6380:6380 -p 26380:26380 -v /home/redis/redis_conf/redis-slave-1.conf:/data/redis.conf -v /home/redis/redis_conf/sentinel2.conf:/data/sentinel.conf –name redis-slave-1 redis:4 redis-server redis.conf #单独启动redis-slave-2容器 同时启动redis-server docker run -d -p 6381:6381 -p 26381:26381 -v /home/redis/redis_conf/redis-slave-2.conf:/data/redis.conf -v /home/redis/redis_conf/sentinel3.conf:/data/sentinel.conf –name redis-slave-2 redis:4 redis-server redis.conf

4.2.2 进入容器

[root@kcx-yk-k8s-master-33 redis_conf]#docker exec -it redis-slave-2 /bin/bash

4.2.3 进入客户端 (注意:如果直接用 redis-cli 进入,默认会进入 6379 端口的 redis 客户端,如果我们三台不同的服务器,主从节点都是用的各自对的 6379 端口就不会有问题,但是如 果像我一样使用的一台服务器,从节点的端口是 6380 和 6381 就需要指定端口进入 redis 客户端) redis-cli -p 6380

4.2.4查看信息(从节点的role为slave)

info replication

备注: 如果 role 为 master ,我们还可以手工指定主节点(ip和端口根据自己的实际情况指定主节点的 ip 和端口) slaveof 127.0.0.1 6379

5 存在的问题:

显示master_link_status的状态为down。表明从节点没有连接到主节点。

基于Docker实现Redis主从+哨兵搭建的示例实践插图2

 查看日志:

1:S 18 Jan 04:20:32.954 # Error condition on socket for SYNC: Connection refused

解决:

原因分析:可能是由于host没有配置主机的默认ip

基于Docker实现Redis主从+哨兵搭建的示例实践插图3

修改后重新启动:一主二从

基于Docker实现Redis主从+哨兵搭建的示例实践插图4

基于Docker实现Redis主从+哨兵搭建的示例实践插图5

基于Docker实现Redis主从+哨兵搭建的示例实践插图6

6、分别启动每个  docker容器里面的哨兵

6.1进入主节点容器

首先进入容器。 docker exec -it redis-master bash

6.2查看文件

用 ls 命令,我们就可以看淡到 sentinel.conf 文件,这个配置文件我们就会用来启动 redis 的哨兵。 ls

基于Docker实现Redis主从+哨兵搭建的示例实践插图7

6.3启动主哨兵服务

redis-sentinel sentinel.conf 

基于Docker实现Redis主从+哨兵搭建的示例实践插图8

6.4 启动两个从哨兵服务

首先进入容器。

docker exec -it redis-slave-1 bash(docker exec -it redis-slave-2 bash)

启动哨兵

redis-sentinel sentinel.conf

6.5进入主哨兵

redis-cli -p 26379

6.6查看哨兵状态

(我们会看到哨兵会显示监听的主节点的信息和从节点的数量,以及现在的哨兵数量。现在的哨兵数量应该为 3 ) info

基于Docker实现Redis主从+哨兵搭建的示例实践插图9

6.7退出哨兵

exit

6.8退出容器

exit

免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞8 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容