Redis主-从部署实践

0. 前言

  这篇文章简要介绍Redis的主从部署,实现了一主二从,使用两个哨兵监控,以实现简单的HA,其中从库作为备机。

1. 部署

  这里有三台服务器,其中239主机上的Redis作为主库,其余两个作为从库。这里涉及到了认证,所以当这里在主库和从库都使用了requirepass和masterauth,因为当主库宕机后,哨兵将其中一个从库提升为主库的时候会要求认证,这里简单起见,配置文件使用了同一配置和密码。

  239主库涉及的配置:

requirepass messagequeue
masterauth messagequeue

  从库涉及相关配置:

slaveof 172.16.17.239 6379

masterauth messagequeue
requirepass messagequeue

  两个哨兵的配置:

sentinel monitor  gateway 172.16.17.239 6379 2
sentinel auth-pass gateway messagequeue

  下图为最终的部署图。

  

最后部署完后可以通过redis-cli连接哨兵查看。

  如下图所示:可以看到主库的ip和端口,从机数量以及哨兵的数量

  

2. 哨兵的详细配置说明:

#端口号
port 26379 # dir <working-directory>
dir /tmp # 监控主数据库
sentinel monitor gateway 172.16.17.239 6379 2 #认证密码
sentinel auth-pass gateway messagequeue #发送PING间隔,大于1秒则按1秒间隔,小于1秒则按配置的时间间隔
sentinel down-after-milliseconds gateway 30000 # 当进行灾备时同时进行重新配置从机的个数
# 当从机用于查询时,用来保证灾备时一定量的从机可以继续服务。
sentinel parallel-syncs gateway 1 # 1.自上次尝试灾备后,再次进行灾备的时间
# 2.从机根据哨兵,从一个错误的主机强制去复制一个正确主机的所需时间,即灾备超时时间。
# 3.取消灾备的时间,即SLAVEOF NO ONE发送到从机,而从机没有应答,超时。
# 4.所有从机配置指向主机的最大时间(灾备总时间)
# 3分钟
sentinel failover-timeout gateway 180000 # 脚本最大运行时间为60秒,当脚本终止码为1时则表示失败重新再次执行(默认最多10次),为2时表成功
# 通知脚本,用以通知管理员(通过SMS,Email等)
# 该脚本传入两个参数,第一个是事件类型,第二个是事件描述
# sentinel notification-script mymaster /var/redis/notify.sh # 客户端重新配置脚本(脚本应该为可重入)
# 用于主库变更时执行一些特定任务,如通知客户端主库变更。
# sentinel client-reconfig-script <master-name> <script-path>
# 下面参数会传递给脚本
# <master-name> <role> <state> <from-ip> <from-port> <to-ip> <to-port>
#
# <state> 永远为 "failover"
# <role> 是"leader" 或者 "observer"
# from-ip/from-port为旧数据库地址
# to-ip/to-port 为变更后主库地址
# sentinel client-reconfig-script mymaster /var/redis/reconfig.sh

3. 哨兵应用

  哨兵提供了一些方法,以供在灾备切换主库后查询主库的信息。

  1. 如上配置文件,可以使用脚本方式来通知。

  2. 可以通过连接哨兵使用 SENTINEL master <master_name>来查询(其中master_name为上述哨兵配置文件sentinel monitor后面的gateway)。

    如下局部代码(采用hiredis库,连接后要使用AUTH命令认证方可操作):

 1     const char *pCommand = "SENTINEL master %s";
2 redisReply *pReply = (redisReply*)redisCommand(pRedisContext->pContext, pCommand, pMasterName);
3
4 if (NULL != pReply)
5 {
6 if (REDIS_REPLY_ARRAY == pReply->type && pReply->elements >= 5)
7 {
8 nMasterIpLen = REDIS_MIN(20, pReply->element[3]->len);
9 memcpy(pMasterIP, pReply->element[3]->str, nMasterIpLen);
10 pMasterIP[nMasterIpLen] = '\0';
11 *pMasterPort = atoi(pReply->element[5]->str);
12 nRet = REDIS_SUCCESS;
13 }
14 freeReplyObject(pReply);
15 }

4. 总结

  如上图所示的部署主要用于公司一个项目,实现在简单的消息队列,这里不采用其他开源消息队列(如activemq,zeromq,rabbitmq等)有一些其他的因素在。

 
分类: Redis

部署Redis主-从的更多相关文章

  1. 阿里云ECS部署Redis主备哨兵集群遇到的问题

    一.部署 详细部署步骤:https://blog.csdn.net/lihongtai/article/details/82826809 Redis5.0版本需要注意的参数配置:https://www ...

  2. docker-compose一键部署redis一主二从三哨兵模式(含密码,数据持久化)

    本篇基于centos7服务器进行部署开发 一.拉取redis镜像,使用如下命令 docker pull redis 1.查看镜像是否拉取成功,使用如下命令 docker images 显示如下则证明拉 ...

  3. k8s 上部署 Redis 三主三从 集群

    目录 介绍 为什么要使用Redis? 什么是Redis群集? 在Kubernetes中部署Redis集群 从 GitHub 上下载: 创建pv 创建statefulset 创建service 初始化 ...

  4. Redis安装部署(一主二从三哨兵)

    需求:根据当前客户的生产环境,模拟安装部署Redis的测试环境,方便后续的功能测试. 1.准备工作 2.安装编译Redis 3.Redis运行环境配置 4.Redis启动和关闭 1.准备工作 Redi ...

  5. K8S部署Redis Cluster集群(三主三从模式) - 部署笔记

    一.Redis 介绍 Redis代表REmote DIctionary Server是一种开源的内存中数据存储,通常用作数据库,缓存或消息代理.它可以存储和操作高级数据类型,例如列表,地图,集合和排序 ...

  6. linux离线部署redis及redis.conf详解

    一.离线部署redis 由于博主部署的虚拟机没有网络也没有gcc编译器,所以就寻找具备gcc编译器的编译环境把redis编译安装好,Copy Redis安装目录文件夹到目标虚拟机的目录下.copy时r ...

  7. SaltStack部署redis主从

    需求: 一,部署redis主从,一台主一台从 二,redis监听自己的IP地址,而不是0.0.0.0 主:安装,配置,启动 从:安装,配置,启动,主从

  8. SaltStack入门篇(六)之部署Redis主从实现和Job管理

    一.部署Redis主从 需求: 192.168.56.11是主,192.168.56.12是从 redis监听自己的ip地址,而不是0.0.0.0 分析: linux-node1 安装 配置 启动 l ...

  9. (六) Docker 部署 Redis 高可用集群 (sentinel 哨兵模式)

    参考并感谢 官方文档 https://hub.docker.com/_/redis GitHub https://github.com/antirez/redis happyJared https:/ ...

随机推荐

  1. Eclipse 改动凝视的 date time 日期时间格式,即${date}变量格式

    Eclipse 改动凝视的 date time 日期时间格式,即${date}变量格式 找到eclipse安装文件夹以下的plugins文件夹,搜索 org.eclipse.text ,找到一个jar ...

  2. 什么样的企业造什么样的软件最easy成功?

    事件1: 一般软件企业按功能分,大体分业务应用型软件和系统工具型软件. 按市场分,应用型软件企业较多,直接贴近生活:系统工具类较少,间接贴近大众较少. 事件2: 软件企业中,当中中小型企业老板存在非常 ...

  3. Keepalived+LVS+Nginx负载均衡之高可用

    Keepalived+LVS+Nginx负载均衡之高可用 上一篇写了nginx负载均衡,此篇实现高可用(HA).系统整体设计是采用Nginx做负载均衡,若出现Nginx单机故障,则导致整个系统无法正常 ...

  4. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第15章节--开发SP2013工作流应用程序 总结

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第15章节--开发SP2013工作流应用程序 总结         在SP2013中,工作流已经从SP Server中脱离 ...

  5. 特里-HDOJ-1671

    Phone List Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  6. 使用scipy进行聚类

    近期做图像的时候,突然有个idea,须要进行聚类,事实上算法非常easy,可是当时非常急.就直接使用了scipy的cluster. 使用起来事实上非常easy,可是中文的文章非常少,所以就简单的介绍一 ...

  7. JavaScript语言基础知识10

    JavaScript中间if声明: <span style="font-size:18px;"><HTML> <HEAD> <TITLE& ...

  8. 假防病毒软件从电脑移植到了 Android 平台

    以前有位女研究生点击网络钓鱼的链接.随即出现实时扫毒画面的方式,接着呈现了扫毒结果,跑出十余笔病毒数据,记录了被感染的计算机的具体位置,并提示她必须更新防病毒软件,而她在付费两千元后收到"防 ...

  9. 【2014 Multi-University Training Contest 3 1002】/【HDU 4888】 Redraw Beautiful Drawings

    不easy啊.最终能够补第二个题了.! 顺便说一句:模版写残了就不要怪出题人啊 ~ (这残废模版研究了好长时间才找出错) 题目大意: 有一个n*m的矩阵.每个格子里都将有一个数.给你每一行数字之和和每 ...

  10. 手机APP有三类:原生APP,WebAPP,HybridApp

    搭建 AngularJS+Ionic+Cordova 开发环境并运行一个demo 目前的手机APP有三类:原生APP,WebAPP,HybridApp:HybridApp结合了前两类APP各自的优点, ...