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

 更新时间:2022年01月21日 09:46:08   作者:熙仪繁华  
本文主要介绍了基于Docker实现Redis主从+哨兵搭建的示例实践,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

1.拉取镜像

docker pull redis:4

2. 编写主 从配置文件

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

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。表明从节点没有连接到主节点。

 查看日志:

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

解决:

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

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

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

6.1进入主节点容器

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

6.2查看文件

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

6.3启动主哨兵服务

redis-sentinel sentinel.conf 

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

6.7退出哨兵

exit

6.8退出容器

exit

到此这篇关于基于Docker实现Redis主从+哨兵搭建的示例实践的文章就介绍到这了,更多相关Docker Redis主从+哨兵搭建内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mac OSX系统 Docker启用Docker远程API功能

    Mac OSX系统 Docker启用Docker远程API功能

    这篇文章主要介绍了Mac OSX系统 Docker启用Docker远程API功能的相关资料,需要的朋友可以参考下
    2016-10-10
  • Docker 打包python的命令详解

    Docker 打包python的命令详解

    最近用Python写了一段爬虫程序,为了隔离其运行环境,易于分发,把项目打包成Docker镜像,下面给大家简单介绍下具体命令写法
    2016-12-12
  • 如何在centos的docker里安装jupyter并开放端口

    如何在centos的docker里安装jupyter并开放端口

    上次有一朋友问小编如何在centos的docker里安装jupyter并开放端口呢?在这就不一一回复大家了,下面小编把我的个人经验分享到脚本之家平台,感兴趣的朋友一起看看吧
    2021-08-08
  • docker registry安装简单命令实现

    docker registry安装简单命令实现

    这篇文章主要介绍了docker registry安装详细介绍的相关资料,需要的朋友可以参考下
    2016-10-10
  • Docker搭建Jenkins并自动化打包部署项目的步骤

    Docker搭建Jenkins并自动化打包部署项目的步骤

    本文主要介绍了Docker搭建Jenkins并自动化打包部署项目的步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • docker部署golang http服务时端口无法访问的问题解决

    docker部署golang http服务时端口无法访问的问题解决

    本文主要介绍了docker部署golang http服务时端口无法访问的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • Docker Desktop搭建RocketMQ的图文步骤

    Docker Desktop搭建RocketMQ的图文步骤

    RocketMQ支持发布/订阅模式和点对点模式,可以根据业务需求选择合适的消息模式,本文主要介绍了Docker Desktop搭建RocketMQ的图文步骤,感兴趣的可以了解一下
    2024-02-02
  • docker-compose部署zk+kafka+storm集群的实现

    docker-compose部署zk+kafka+storm集群的实现

    这篇文章主要介绍了docker-compose部署zk+kafka+storm集群,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • docker守护进程的配置和操作的方法

    docker守护进程的配置和操作的方法

    这篇文章主要介绍了docker守护进程的配置和操作的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • docker部署zabbix_agent的方法步骤

    docker部署zabbix_agent的方法步骤

    这篇文章主要介绍了docker部署zabbix_agent的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10

最新评论