使用docker搭建reids主从,哨兵。
Redis主从配置,如果没有真机就要用虚拟机,使用Docke for Windows host网络有问题。
准备:
1.安装虚拟机。
2.下载redis的安装文件:http://download.redis.io/releases/redis-5.0.7.tar.gz
1.redis-5.0.7/redis.conf
->Redis 配置文件。
2.redis-5.0.7/sentinel.conf
->哨兵配置文件。
主从配置:
1.将redis.conf 复制 3 份名为 redis-master.conf,redis-slave1.conf,redis-slave2.conf ,redis-master作为主服务器,内容除端口、密码外其他基本不用进行修改。
2.修改配置文件:
redis-master.conf
1.bind 127.0.0.1 改为 bind 0.0.0.0 或者注释
bind 与网卡对应的ip才能连接。
2.添加master密码
requirepass abc123
3.端口:
测试使用默认 6379端口。
redis-slave.conf
1.bind 127.0.0.1 改为 bind 0.0.0.0 或者注释
2.确定主redis地址
replicaof 192.168.10.202 6379
3.主密码
masterauth abc123
4.添加密码
requirepass abc123
5.端口分别为6380,和6381
两个从redis都是这样配置。

启动主从redis。
1.启动master:
docker run --rm --network host --name redis-master -v /home/ye/SystemConfig/RedisConfig/redis-master.conf:/usr/local/etc/redis/redis.conf -d redis redis-server /usr/local/etc/redis/redis.conf
2.启动从redis:
docker run --rm --name redis-slave1 --network host -v /home/ye/SystemConfig/RedisConfig/redis-slave1.conf:/usr/local/etc/redis/redis.conf -d redis redis-server /usr/local/etc/redis/redis.conf
docker run --rm --name redis-slave2 --network host -v /home/ye/SystemConfig/RedisConfig/redis-slave2.conf:/usr/local/etc/redis/redis.conf -d redis redis-server /usr/local/etc/redis/redis.conf
至此,一主两从配置好了。
redis-cli连接master:redis-cli -h 192.168.10.202 -p 6379 -a abc123
使用命令:info replication

可以看到有两台从机,我们可以在master读写,但在从slave只能读。
测试:
master:

slave:

哨兵模式:
1.虽然主从能够应对大多数高并发的情景,但是如果当master挂掉后,将无法写入新数据,也需要维护连接,需要人工进行恢复。因此需要采用自动化的机制来保证高可用。
2.哨兵模式将会自动进行以下动作。
1.不停的监控redis是否按照预期良好的运行。
2.如果发现某个redis节点出现状态,能够通知另一个进程(例如他的客户端)
3.能够进行自动切换,当一个master节点不可用时,能够选举出master的多个slave(如果超过一个slave的情况)钟的一个来作为新的master,其他的slave节点将会将它所追随master的地址改为被提升的为master的slave的新地址。
4.如果哨兵作为客户端提供服务发现,客户端连接哨兵,哨兵将提供当前master的地址提供服务,如果出现切换,也就是master挂了,哨兵将会提供客户端一个新地址。
3.哨兵的改变将在所有节点重启后恢复原来的配置,原master重启后将会变成slave节点。
配置哨兵:
1.复制sentinel.conf 为 redis-sentinel.conf
2.修改配置文件:
1.监控地址:(监视名称) (地址) (端口) (投票数,获得这么多同意后,将选举为master主机,两台从机,所有我写2)
sentinel monitor mymaster 192.168.10.202 6379 2
2.监控时间 (名称) (超时时间,当超过这个时间,则认为master已经挂了)
sentinel down-after-milliseconds mymaster 10000
3.设置连接redis主从密码
sentinel auth-pass mymaster abc123
4.设置bind 为 bind 0.0.0.0
3.注意配置文件项有先后顺序。
启动哨兵:
docker run --rm --name redis-sentinel --network host -v /home/ye/SystemConfig/RedisConfig/redis-sentinel.conf:/usr/local/etc/redis/sentinel.conf -d redis /usr/local/bin/redis-sentinel /usr/local/etc/redis/sentinel.conf

此时停止master:

可以看到主已经变为6381了。

支持,主从已经哨兵已经搭建完成,持久化那就是另一回事了。
使用docker搭建reids主从,哨兵。的更多相关文章
- linux系统——Redis集群搭建(主从+哨兵模式)
趁着这几天刚好有点空,就来写一下redis的集群搭建,我跟大家先说明,本文的redis集群因为linux服务器只是阿里云一台服务器,所以集群是redis启动不同端口,但是也能达到集群的要求.其实不同服 ...
- docker搭建redis主从集群和sentinel哨兵集群,springboot客户端连接
花了两天搭建redis主从集群和sentinel哨兵集群,讲一下springboot客户端连接测试情况 redis主从集群 从网上查看说是有两种方式:一种是指定配置文件,一种是不指定配置文件 引用地址 ...
- 新手之:SpringBoot ——Reids主从哨兵整合(CentOS7)
一.Redis主从搭建(一台服务器模拟多个端口) 结构图:) 1.确保安装了Redis,我装在了/opt/redis目录下.可通过"whereis redis-cli"命令查看是否 ...
- 基于 docker 的redis 主从+哨兵(快速部署)
很简单(字多的步骤见:http://www.cnblogs.com/vipzhou/p/8580495.html) 1.直接启动3个容器 docker network create --subnet ...
- 使用docker搭建redis主从模式
前期准备: 本地Linux版本:CentOS Linux release 7.5.1804 (Core)Docker版本:Docker version 1.13.1, build dded712/1. ...
- Docker搭建MySQL主从集群,基于GTID
写在前边 搭建MySQL读写分离主从集群,这里未使用binlog方式,使用的是GTID方式 源码见我的Github https://github.com/hellxz/mysql-cluster-do ...
- Redis主从&哨兵集群搭建
主从集群 在搭建主从集群前,我们先把Redis安装起来: #解压Redis压缩包 [root@master lf]# tar -zxvf redis-6.2.1.tar.gz -- #安装gcc [r ...
- Docker构建mysql主从
一.为什么要搭建主从架构呢 1.数据安全,可以进行数据的备份. 2.读写分离,大部分的业务系统来说都是读数据多,写数据少,当访问压力过大时,可以把读请求给到从服务器.从而缓解数据库访问的压力 3.故障 ...
- redis 安装 集群 主从 哨兵 docker
安装redis 官方文档 docker run -d --net host -v /opt/myconfig/redis/redis.conf:/usr/local/etc/redis/redis.c ...
随机推荐
- springboot配置Filter的两种方法
一.使用注解1. 假设Filter类的路径为com.sanro.filter @Slf4j @WebFilter(filterName = "authFilter", urlPat ...
- IDEA子项目的相互依赖
A项目依赖B项目 一.B项目打包,执行install 这一步其实就是把你的项目打包到本地仓库,你可以在本地仓库看到相应的jar包 二.在A项目的pom.xml引入依赖可以了 当B项目修改后,需要重新打 ...
- ES6深入浅出-4 迭代器与生成器-5.科班 V.S. 培训
为什么要学用不到的东西 科班是把你未来一二十年用的东西都给你入个门 做前端 三年后一定要再学一门语言. 买一本图解算法 培训讲究的是技能,只能满足3到5年,而不是术,学术学的是你未来10年甚至20年用 ...
- k8s记录-使用kube-proxy让外部网络访问K8S service的ClusterIP (转载)
配置方式 kubernetes版本大于或者等于1.2时,外部网络(即非K8S集群内的网络)访问cluster IP的办法是:修改master的/etc/kubernetes/proxy,把KUBE_P ...
- CentOS7下搭建Redis主从复制
(1).实验环境 youxi1 192.168.1.6 Master服务器 youxi2 192.168.1.7 Slave服务器 (2).实验 1)两台服务器上yum安装Redis,启动并设置开机自 ...
- python 的环境变量
import sys,os BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__))) sys.path.append(B ...
- 13、OpenCV实现图像的空间滤波——图像平滑
1.空间滤波基础概念 1.空间滤波基础 空间滤波一词中滤波取自数字信号处理,指接受或拒绝一定的频率成分,但是空间滤波学习内容实际上和通过傅里叶变换实现的频域的滤波是等效的,故而也称为滤波.空间滤波主要 ...
- Tuner工作原理详解
1.TV自动搜台原理:https://wenku.baidu.com/view/3b771f8b84868762caaed514 2.彩电自动搜台的原理与维修:http://tv.baoxiu.c ...
- 关于typescript之定义变量和数据类型那点事
变量和数据类型 JavaScript虽说深受万千程序员喜爱,却有着对于企业大规模开发很难管理的缺陷.这时候,TypeScript的优势便体现出来.接下来,我们会先接触在TypeScript中定义变量相 ...
- [学习笔记] 下载、安装、启动 Eclipse(OEPE)
OEPE 的全称是: Oracle Enterprise Pack for Eclipse 截止目前的最新版本是:(12.2.1.9) 下载地址:(需要在甲骨文官网注册一个账户才能下载) https: ...