redis主从,哨兵,集群
本次所有操作在docker下进行,搭建方便,迅速构建redis集群。
1. docker安装redis
- 获取redis:latest(使用官方最新的) 镜像
$ docker pull redis
redis.conf、sentinel.conf 配置
官方下载
redis安装(一主二从)
容器外目录位置 /vagrant/app/redis
redis.conf复制三份,分别为redis-master、redis-slave1、redis-salve2;
sentinel.conf复制三份,分别为sentinel-master、sentinel-slave1、sentinel-slave2;
$ docker run -it -v /vagrant/app/redis/redis.conf:/usr/local/etc/redis/redis.conf -v /vagrant/app/redis/sentinel-master.conf:/usr/local/etc/redis/sentinel.conf --name redis-master -p 6379:6379 -d redis
$ docker run -it -v /vagrant/app/redis/redis-slave1.conf:/usr/local/etc/redis/redis.conf -v /vagrant/app/redis/sentinel-slave1.conf:/usr/local/etc/redis/sentinel.conf --link redis-master:master --name redis-slave1 -p 6380:6379 -d redis
$ docker run -it -v /vagrant/app/redis/redis-slave2.conf:/usr/local/etc/redis/redis.conf -v /vagrant/app/redis/sentinel-slave2.conf:/usr/local/etc/redis/sentinel.conf --link redis-master:master --name redis-slave2 -p 6381:6379 -d redis
-v 参数用于将宿主机上的某个目录挂载到容器中
--link redis-master:master参数,前面提到的redis-slave.conf配置文件中slaveof配置项,这里使用了一个master作为别名,其效果和使用IP一样(IP地址在/etc/host文件中)。
2. redis集群,配置主从复制
分别进入三台redis容器内(docker exec -it 容器id /bin/bash),redis-cli 连接redis服务端;
连接后,使用info replication 查看当前机器角色,都为master主机;
在redis-slave1、redis-slave2下,使用 slaveof master 6379 命令,建立主从联系;再次使用 info replication查看当前role
并且master主机可以看到连接connectd-slaves:2,主从配置成功。
redis-master主机下,执行 set sun 111,可以看到slave1、slave2能 get sun,返回结果 111;
3. 添加哨兵
三台redis容器服务器,互相启动一个redis哨兵。
查看容器ip,docker inspect <容器id>
docker inspect redis-master
分别对sentinel-master.conf、sentinel-slave1.conf、sentinel-slave2.conf,编辑修改:
sentinel monitor redis-master 172.17.45.8 6379 2
##其余mymaster的地方统一修改为 redis-master
分别进入容器内,执行如下命令:
redis-sentinel /usr/local/etc/redis/sentinel.conf
4. 检测
dockers ps -a 可以看到三个正在运行的redis服务器
dockers stop redis-master 停止redis-master服务再启动,打开容器redis-slave1(可能redis-slave2),执行redis-cli,info查看:
可以看到,redis-slave1已升级为master
redis 配置文件实现主从
所有redis.conf文件中 所有bind ip 改为 0.0.0.0 (任意ip可连)
docker run -it -p 6379:6379 -v /vagrant/app/redis/redis-master.conf:/usr/local/etc/redis/redis.conf --name redis-master -d redis redis-server /usr/local/etc/redis/redis.conf
docker run -d -p 6380:6379 -v /vagrant/app/redis/redis-slave1.conf:/usr/local/etc/redis/redis.conf --link redis-master:master --name redis-slave1 redis redis-server /usr/local/etc/redis/redis.conf
docker run -d -p 6381:6379 -v /vagrant/app/redis/redis-slave2.conf:/usr/local/etc/redis/redis.conf --link redis-master:master --name redis-slave2 redis redis-server /usr/local/etc/redis/redis.conf
查看容器日志,可以帮助我们快速找到问题
docker logs <容器id>
不出意外主从配置完成,接下来配置sentinel:
- 修改配置文件 sentinel.conf
sentinel-master.conf
protected-mode no
sentinel monitor mymaster master 6379 2 # master 别名,定位reids-master ip
sentinel-slave1.conf
protected-mode no
sentinel monitor mymaster slave1 6379 2 # slave1 别名,定位redis-slave1 ip
sentinel-slave2.conf
protected-mode no #是否开启保护模式,默认开启。要是配置里没有指定bind和密码。开启该参数后,redis只会本地进行访问,拒绝外部访问。要是开启了密码 和bind,可以开启。否 则最好关闭,设置为no。
sentinel monitor mymaster slave2 6379 2 #Sentinel去监视一个名为mymaster的主redis实例, slave2 别名,定位redis-slave2 ip
启动sentinel服务:
# 监控redis-master节点
docker run -d -p 5000:26379 -v /vagrant/app/redis/sentinel-master.conf:/usr/local/etc/redis/sentinel.conf --link redis-master:master --name sentinel-master redis redis-server /usr/local/etc/redis/sentinel.conf --sentinel
# 监控redis-slave1节点
docker run -d -p 5001:26379 -v /vagrant/app/redis/sentinel-slave1.conf:/usr/local/etc/redis/sentinel.conf --link redis-slave1:slave1 --name sentinel-slave1 redis redis-server /usr/local/etc/redis/sentinel.conf --sentinel
# 监控redis-slave2节点
docker run -d -p 5002:26379 -v /vagrant/app/redis/sentinel-slave1.conf:/usr/local/etc/redis/sentinel.conf --link redis-slave2:slave2 --name sentinel-slave2 redis redis-server /usr/local/etc/redis/sentinel.conf --sentinel
sentinel 可通过主节点找到下列所有子节点,进行故障调度,为每个节点设定sentinel,相互监控,安全可靠性高。
如此实现哨兵,主从。优点,方便启动,易于调整,故障处理风险低;
redis主从,哨兵,集群的更多相关文章
- 【Redis学习专题】- Redis主从+哨兵集群部署
集群版本: redis-4.0.14 集群节点: 节点角色 IP redis-master 10.100.8.21 redis-slave1 10.100.8.22 redis-slave2 10.1 ...
- Redis主从&哨兵集群搭建
主从集群 在搭建主从集群前,我们先把Redis安装起来: #解压Redis压缩包 [root@master lf]# tar -zxvf redis-6.2.1.tar.gz -- #安装gcc [r ...
- 三千字介绍Redis主从+哨兵+集群
一.Redis持久化策略 1.RDB 每隔几分钟或者一段时间会将redis内存中的数据全量的写入到一个文件中去. 优点: 因为他是每隔一段时间的全量备份,代表了每个时间段的数据.所以适合做冷备份. R ...
- redis主从、集群、哨兵
redis的主从.集群.哨兵 参考: https://blog.csdn.net/robertohuang/article/details/70741575 https://blog.csdn.net ...
- redis的哨兵集群,redis-cluster
#主从同步redis主从优先1.保证数据安全,主从机器两份数据一主多从2.读写分离,缓解主库压力主redis,可读可写slave身份,只读 缺点1.手动主从切换假如主库挂了,得手动切换master ...
- redis:哨兵集群配置
最少配置1主2从3哨兵 一.引言 上一篇文章我们详细的讲解了Redis的主从集群模式,其实这个集群模式配置很简单,只需要在Slave的节点上进行配置,Master主节点的配置不需要做任何更改,但是有一 ...
- 走进Redis:哨兵集群
为什么需要哨兵 在 Redis 的主从库模式中,如果从库发生了故障,用户的操作是可以继续进行的,因为写操作是只在主库中进行的.那么,如果主库发生了故障,用户的操作将会收到影响.这时候可能会需要选择一个 ...
- Redis Sentinel哨兵集群
Redis Sentinel(哨兵集群)是一种高可用的redis部署方案.在集群中的redis-master服务挂掉时,无需人为干预,即可通过哨兵集群的自我调整,实现redis服务的持续可用. 哨兵集 ...
- redis的哨兵集群,自动切换主从库
Redis-Sentinel是redis官方推荐的高可用性解决方案,当用redis作master-slave的高可用时,如果master本身宕机,redis本身或者客户端都没有实现主从切换的功能. 而 ...
- Redis高可用-主从,哨兵,集群
主从复制 Master-Slave主从概念 同时运行多个redis服务端,其中一个作为主(master),其他的一个或多个作为从(slave),主从之间通过网络进行通讯,slave通过复制master ...
随机推荐
- 最新 IntelliJ Idea 2017 激活方法(转)
转载地址:http://www.cnblogs.com/suiyueqiannian/p/6754091.html 1. 到网站 http://idea.lanyus.com/ 获取注册码. 2.填入 ...
- Response.cookies和Request.cookies
Response.cookies和Request.cookies的区别很重要,由于方法基本都是差不多的,特别对于初学者而言,很容易出现混淆. 简单说就是创建cookie用response,获取cook ...
- 【C#】RGB转CMYK
由于目前印兔项目中的在线设计功能设计出来的产品颜色模式不确定,但是客户设计出来的产品需要发送到印厂的客户端去下载并且印刷,只有CMYK颜色模式的产品才能正确印刷,所以需要判断产品的颜色模式是否为CMY ...
- JS 教程
1简介 1.JavaScript 是脚本语言 1.1轻量级的编程语言 1.2可插入 HTML 页面的编程代码 1.3可由所有的现代浏览器执行 2.您将学到什么 2.1JavaScript:写入 HTM ...
- 微服务系列(二):使用 API 网关构建微服务
编者的话|本文来自 Nginx 官方博客,是微服务系列文章的第二篇,本文将探讨:微服务架构是如何影响客户端到服务端的通信,并提出一种使用 API 网关的方法. 作者介绍:Chris Richardso ...
- 撩课-Web大前端每天5道面试题-Day3
1. javascript的typeof返回哪些数据类型? 答案: undefined string boolean number symbol(ES6) Object Function 2. 列举3 ...
- 1.Java设计模式-工厂模式
1.简单工厂模式(Factory Method) 常用的工厂模式是静态工厂模式,利用static修饰方法,作为一种类似于常见的工具类Utils等辅助效果,一般情况下工厂类不需要实例化. //1.定义一 ...
- Java设计模式浅谈
1.java的设计模式可以分为3类: 创建型模式(5种):工厂模式,抽象工厂模式,建造者模式,单例模式,原型模式: 结构型模式(7种):适配器模式,装饰器模式,代理模式,外观模式,桥接模式,组合模式和 ...
- JDBC的DAO设计模式
在javaEE中,java类的属性通过getter和setter来定义,get(或set)方法去除get(set)后,首字母小写即为Java类的属性.操作java类的属性有一个工具包,BeanUtil ...
- 12、springboot注解
@RestController和@Controller import java.lang.annotation.Documented; import java.lang.annotation.Elem ...