前言:只有一台华为云服务器,所以打算创建三个容器来模拟三个服务器了。

一:拉取redis镜像

二:拉取redis.conf文件

放在自定义的目录下:wget -c http://download.redis.io/redis-stable/redis.conf

三:启动三个redis容器,redis_1,redis_2,redis_3

 --name:自定义启动容器名称
-v 主机redis.conf 和redis容器做映射
-d 后台启动
-p 端口映射 6379是redis端口 26379是哨兵端口
redis:镜像名称
docker run --name redis_1 -v /usr/local/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf -d -p 6379:6379 -p 26379:26379 redis

四:测试三个单机redis

进入容器:

docker  exec  -it  容器id  /bin/bash

 docker exec -it 1e8c3a92a6f4 /bin/bash

执行redis-cli进入redis

功能正常之后查看角色,因为现在刚创建出来都是单机的。输入:info  命令显示都是master

五:手动设置主从关系

这里使用到的IP是容器里的IP,可以通过:docker inspect redis_1查看容器映射出来的ip。

我们这里把redis_1设置为主,redis_2,redis_3设置为从。

进入redis_2容器,打开redis-cli,输入 SLAVEOF IP  PORT

即可完成主机的绑定,再次执行INFO命令就可以看到角色发生了变化,且主机也显示了。

redis_3也这样执行。

执行完我们进入redis_1中,执行INFO可以看到主从关系已经生效:

六:测试主从关系

在redis_1中执行set命令可以正常set,get。

我们去redis_2,redis_3中看下能否获取到。

redis_2正常获取

这里需要注意的一点,SLVAE角色的redis只能读取不能set的。

只有master才能读写。

redis_3也是这样的。

 redis主从复制集群的特点,读写分离。

七:在主从集群的基础上搭建哨兵模式

进入三个redis容器,

1: 先更新在安装vim

apt-get update
apt-get install -y vim

在容器的根目录下创建sentinel.conf文件。vim sentinel.conf。写入以下配置:

port 26381 #哨兵端口号 一定要和启动命令映射第二个端口号一致  26379   26380  26381
daemonize yes #后台启动
sentinel monitor master_redis 主节点ip 主节点端口 2 #这里的ip也是master容器映射出来的ip 端口是master映射到外面的端口 6379 最后的2表示 有2两个哨兵

2: 执行这个配置文件:redis-sentinel sentinel.conf

查看运行的sentinel进程:

在容器里安装ps命令。

 apt-get install procps

安装成功之后  :ps -ef 看到sentinel进程已经启动了。

三个容器的哨兵进程都启动后,可以看到

可以测试下把master节点的redis停掉,过一会slave中的某个节点会担任master节点。

单台服务器-利用docker搭建Redis哨兵集群模式的更多相关文章

  1. docker搭建redis主从集群和sentinel哨兵集群,springboot客户端连接

    花了两天搭建redis主从集群和sentinel哨兵集群,讲一下springboot客户端连接测试情况 redis主从集群 从网上查看说是有两种方式:一种是指定配置文件,一种是不指定配置文件 引用地址 ...

  2. Docker 搭建 Redis Cluster 集群环境

    使用 Docker 搭建 Redis Cluster,最重要的环节就是容器通信的问题,这一块我们在之前的文章中已经给大家解决了<Docker 网络模式详解及容器间网络通信>,本篇文章主要练 ...

  3. Redis进阶实践之十 Redis哨兵集群模式

    一.引言             上一篇文章我们详细的讲解了Redis的主从集群模式,其实这个集群模式配置很简单,只需要在Slave的节点上进行配置,Master主节点的配置不需要做任何更改,但是有一 ...

  4. docker-compose搭建redis哨兵集群

    头脑风暴 出于学习目的,您可以很轻松地在docker环境下运行redis的单个实例,但是如果您需要在生产环境中运行它,那么必须将Redis部署为HA(High Avaliable)模式. Redis ...

  5. Docker Compose 搭建 Redis Cluster 集群环境

    在前文<Docker 搭建 Redis Cluster 集群环境>中我已经教过大家如何搭建了,本文使用 Docker Compose 再带大家搭建一遍,其目的主要是为了让大家感受 Dock ...

  6. redis哨兵集群搭建

    下载redis jar包redis-4.0.11.tar.gz放在/data/redis目录下 解压 命令:tar -zxvf redis-4.0.11.tar.gz 解压后如图所示 在/usr/lo ...

  7. 一、全新安装搭建redis主从集群

    前言· 这里分为三篇文章来写我是如何重新搭建redis主从集群和哨兵集群的及原本服务器上有单redis如何通过升级脚本来实现redis集群.(redis结构:主-从(备)-从(备)) 至于为什么要搭建 ...

  8. 【精】搭建redis cluster集群,JedisCluster带密码访问【解决当中各种坑】!

    转: [精]搭建redis cluster集群,JedisCluster带密码访问[解决当中各种坑]! 2017年05月09日 00:13:18 冉椿林博客 阅读数:18208  版权声明:本文为博主 ...

  9. 11.Redis 哨兵集群实现高可用

    作者:中华石杉 Redis 哨兵集群实现高可用 哨兵的介绍 sentinel,中文名是哨兵.哨兵是 redis 集群机构中非常重要的一个组件,主要有以下功能: 集群监控:负责监控 redis mast ...

随机推荐

  1. Spring Boot 2.4版本前后的分组配置变化及对多环境配置结构的影响

    前几天在<Spring Boot 2.4 对多环境配置的支持更改>一文中,给大家讲解了Spring Boot 2.4版本对多环境配置的配置变化.除此之外,还有一些其他配置变化,所以今天我们 ...

  2. SQL 查询增加语句

    Select 'Insert into Auth_Key Values('''+convert(nvarchar(50),NEWID())+''','''+AuthKey+''',''' +Modul ...

  3. Autofac官方文档翻译--一、注册组件--1注册概念

    官方文档:http://docs.autofac.org/en/latest/register/registration.html 一.注册概念 使用Autofac 注册组件,通过创建一个Contai ...

  4. win10/win7下vs2013自带IISExpress支持局域网访问

    打开IISExpress安装目录(C:\Users\Administrator\Documents\IISExpress\config),一般为我的文档下,用记事本打开applicationhost. ...

  5. python基本输入与输出

    内置函数print()用于输出信息到标准控制台或指定文件,语法格式为: print(value1,value2,... , sep=' ', end='\n', file=sys.stdout, fl ...

  6. 解决面具magisk刷入模块卡开机问题

    手机刷入面具模块出现卡开机第二屏,在reccovery模式下,点击高级(advanced)->文件管理(File Manager)->data->adb->modules删掉对 ...

  7. Linux性能优化:CPU性能分析工具--vmstat

    Blog:博客园 个人 目录 参数说明 输出信息说明 procs memory swap io system cpu 示例 vmstat是Virtual Meomory Statistics(虚拟内存 ...

  8. Spring IOC 笔记

    什么是IOC与DI IOC(inversion of control) 它描述的其实是一种面向对象编程中的设计原则,用来降低代码之间的耦合度, 而DI(dependency Injection)依赖注 ...

  9. springboot 日期参数前后台转换问题

    方式 一: 在实体类上加@DatetimeFormat与@JsonFormat注解 @DatetimeFormat:将前台日期字符串转换成Date格式 @DateTimeFormat(pattern= ...

  10. .Net Core — 依赖注入

    在.NET Core 中 依赖注入Dependency-Injection)作为基础知识,在.Net Core中无处不在:这么重要的知识接下来就了解和在.Net Core中使用. 一.依赖注入 说到依 ...