第一部分 Redis-HA 搭建

一、Redis-HA 拓扑

一主两从,主从复制,故障时主从切换

三个Redis节点 + Sentinel 节点

Master          127.0.0.1       6379

Slave1       127.0.0.1       6380

Slave2       127.0.0.1       6381

二、环境准备

1 操作系统

CentOS 6.5

2 相关软件

jdk8

Tomcat8

Redis-3.2.8.tar.gz (官网下载)

三、Redis 主从配置

1 将redis-3.2.8.tar.gz 版本,并上传到 Redis 部署服务器上

注:使用xftp 或者 winscp等软件,上传至/opt/softwareRes/ 目录下。

2 建Redis 安装目录

mkdir -p /opt/stools/redis/redis-3.2.8.master/

mkdir -p /opt/stools/redis/redis-3.2.8.slave-1/

mkdir -p /opt/stools/redis/redis-3.2.8.slave-2/

 

分别解压安装包到 Redis 安装目录

cd /opt/softwareRes/

tar zxvf redis-3.2.8.tar.gz -C /opt/stools/redis/redis-3.2.8.master/ --strip-components 1

tar zxvf redis-3.2.8.tar.gz -C /opt/stools/redis/redis-3.2.8.slave-1/ --strip-components 1

tar zxvf redis-3.2.8.tar.gz -C /opt/stools/redis/redis-3.2.8.slave-2/ --strip-components 1

3 分别进入 master、slave-1、slave-2 下的src 文件夹,安装及测试

以master为例

cd /opt/stools/redis/redis-3.2.8.master/src

make

make test

测试通过会提示:All tests passed without errors!

注:如果提示 you need tcl .. 可以使用 yum -y install tcl 进行安装。

注:之后再slave-1、slave-2 下的src分别执行安装测试。

4 配置

master 节点 redis.conf 配置内容(未涉及的保持不变)

# 绑定地址(可配置多个,内外网)

bind 17.13.11.10 127.0.0.1

# 服务端口

port 6379

# pid文件位置

pidfile /var/run/redis_6379.pid

# 日志文件位置

logfile "/data/logs/redis.master.log"

#

daemonize yes

# 保护模式

protected-mode no

#

masterauth "spads"

# 访问数据秘钥

requirepass "spads"

slave1 节点 redis.conf 配置内容(未涉及的保持不变)

# 绑定地址(可配置多个,内外网)

bind 17.13.11.10 127.0.0.1

# 服务端口

port 6380

# pid文件位置

pidfile /var/run/redis_6380.pid

# 日志文件位置

logfile "/data/logs/redis.master.log"

#

daemonize yes

# 保护模式

protected-mode no

#

masterauth "spads"

# 访问数据秘钥

requirepass "spads"

# 从

slaveof 17.13.11.10 6379

 

slave2 节点 redis.conf 配置内容(未涉及的保持不变)

# 绑定地址(可配置多个,内外网)

bind 17.13.11.10 127.0.0.1

# 服务端口

port 6381

# pid文件位置

pidfile /var/run/redis_6381.pid

# 日志文件位置

logfile "/data/logs/redis.master.log"

#

daemonize yes

# 保护模式

protected-mode no

#

masterauth "spads"

# 访问数据秘钥

requirepass "spads"

# 从

slaveof 17.13.11.10 6379

5启动

cd /opt/stools/redis/redis-3.2.8.master/

./src/redis-server redis.conf

 

cd /opt/stools/redis/redis-3.2.8.slave-1/

./src/redis-server redis.conf

 

cd /opt/stools/redis/redis-3.2.8.slave-2/

./src/redis-server redis.conf

6 测试

(1)测试主从同步:

使用客户端连接主节点,添加key-value, 使用客户端连接从节点,按key取value

redis-cli -h 17.13.11.10 -p 6379 -a spads

set name zzz

exit

 

redis-cli -h 17.13.11.10 -p 6380 -a spads

get name

# 检验是否可以取出 “zzz”

 

(2)测试从节点不可写:

redis-cli -h 17.13.11.10 -p 6380 -a spads

set name xxx 

#检验是否提示如下内容

(error) READONLY You can't write against a read only slave.

四、Sentinel 配置

1 配置

cd /opt/stools/redis/redis-3.2.8.master/

sentinel.conf 配置文件

--------------------------------------

sentinel monitor mymaster 17.13.11.10 6379 1

# 定义监控的Redis 主节点

# mymaster 为自定义的主节点名称,需保证与之后的配置一致 

# 17.13.11.10 为主节点IP地址

# 6379  为主节点服务端口

# 1  为 sentinel 节点数量(quorum )。。。

--------------------------------------

sentinel down-after-milliseconds mymaster 60000

# 表示当master redis 60s 没有应答时,就可以断定master挂掉了,但需要结合上面配置的quorum一起

--------------------------------------

sentinel auth-pass mymaster spads

# 设置主节点的秘钥

--------------------------------------

sentinel config-epoch mymaster 9

# 选项指定了在执行故障转移时, 最多可以有多少个从服务器同时对新的主服务器进行同步, 这个数字越小, 完成故障转移所需的时间就越长

--------------------------------------

2 启动

cd /opt/stools/redis/redis-3.2.8.master/

./src/redis-server sentinel.conf --sentinel & 

3 测试

可以在几个节点都启动情况下,杀掉主节点服务,检验是否更换主节点并生效提供服务。

第二部分 Tomcat 集群下 Session 共享

Nginx + 2 * Tomcat 环境下 的Session 共享。此处直接在Tomcat 中配置 Redis Session存储。

1 各节点Tomcat lib 下增加如下库

commons-pool2-2.3.jar、jedis-2.7.2.jar、redissessionjar.jar、tomcat-juli-8.5.13.jar、commons-logging-1.1.3.jar

其中 redissessionjar.jar

出处 https://github.com/jcoleman/tomcat-redis-session-manager

需下载到本地,然后构建,并修改其中  RedisSessionManager.java 代码。

步骤    1> github 下载 tomcat-redis-session-manager 项目

2> eclipse 创建maven工程,并将 src/main/java/com/orangefunction/tomcat/redissessions/ 拷贝到工程。

3> 增加依赖包

Tomcat8 下面的所有lib (检查是否存在 tomcat-juli-8.5.13.jar,没有需单独下载)/ jedis-2.7.2.jar / commons-pool2-2.3.jar / commons-logging-1.1.3.jar

4> 修改 RedisSessionManager.java

        5>右键工程 export 导出jar包

2 各节点Tomcat 在 conf 下 context.xml,增加如下内容

<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />

<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"

        <!-- host="17.13.11.10" -->

        <!-- port="6378" -->

        database="0"

        password="spads"

        maxInactiveInterval="60"

        sentinelMaster="mymaster"

        sentinels="17.13.11.10:26379"

/>

第三部分 JedisSentinelPool 客户端连接 Redis - HA

jedis.xml 文件配置

<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">

<property name="maxTotal" value="30" />

<property name="maxIdle" value="30" />

<property name="maxWaitMillis" value="30000" />

<property name="testOnBorrow" value="false" />

<property name="testOnReturn" value="true" />

</bean>

 

<bean id="jedisSentinelPool" class="redis.clients.jedis.JedisSentinelPool">

<constructor-arg index="0" value="mymaster" />

<constructor-arg index="1">

<set>

<value>17.13.11.10:26379</value>

</set>

</constructor-arg>

<constructor-arg index="2" ref="jedisPoolConfig" />

<constructor-arg index="3" value="20000" />

<constructor-arg index="4" value="spads" />

</bean>

java 程序中可以通过 resource 注解,获取到 jedisSentinel实例进行缓存操作。

Redis3.x HA 方案(基于 Sentinel 方式)的更多相关文章

  1. ActiveMQ笔记(3):基于Networks of Brokers的HA方案

    上一篇介绍了基于ZK的ActiveMQ HA方案,虽然理解起来比较容易,但是有二个不足: 1)  占用的节点数过多,1个zk集群至少3个节点,1个activemq集群也至少得3个节点,但其实正常运行时 ...

  2. ActiveMQ笔记(2):基于ZooKeeper的HA方案

    activemq官网给出了3种master/slave的HA方案,详见:http://activemq.apache.org/masterslave.html,基于共享文件目录,db,zookeepe ...

  3. 基于Networks of Brokers的HA方案

    上一篇介绍了基于ZK的ActiveMQ HA方案,虽然理解起来比较容易,但是有二个不足: 1)  占用的节点数过多,1个zk集群至少3个节点,1个activemq集群也至少得3个节点,但其实正常运行时 ...

  4. 基于使用ISCSI存储的ibmmq通过heartbeat实现HA方案以及碰到的问题总结

    一.背景 ibmmq是一种传统架构的mq产品,运行稳定,有其自身优点,但在高可用(HA)这一块需要使用公司根据自身需求选用高可用(HA)产品,但由于市面HA商业产品较贵,所以使用linux操作系统级的 ...

  5. Hadoop HA方案调研

    原文成文于去年(2012.7.30),已然过去了一年,很多信息也许已经过时,不保证正确,与Hadoop学习笔记系列一样仅为留做提醒. ----- 针对现有的所有Hadoop HA方案进行调研,以时间为 ...

  6. Zabbix 6.0:原生高可用(HA)方案部署

    Blog:博客园 个人 本部署文档适用于CentOS 8.X/RHEL 8.X/Anolis OS 8.X/AlmaLinux 8.X/Rockey Linux 8.X. 原生的HA方案终于来了 相比 ...

  7. hadoop2.x通过Zookeeper来实现namenode的HA方案以及ResourceManager单点故障的解决方案

    我们知道hadoop1.x之前的namenode存在两个主要的问题:1.namenode内存瓶颈的问题,2.namenode的单点故障的问题.针对这两个问题,hadoop2.x都对它进行改进和解决.其 ...

  8. 技术实战:基于 MHA 方式实现 MySQL 的高可用(转)

    转自:http://os.51cto.com/art/201307/401702_all.htm MHA故障转移可以很好的帮我们解决从库数据的一致性问题,同时最大化挽回故障发生后的数据.本文分享了基于 ...

  9. svg操纵方案 基于 D3 还是 angular?

    之前还是想简单了, 现在重新写这篇.把逻辑拆分粒度的辨析,放到外面去. 问题提出:svg控制方案 基于 D3 还是 angular 根据这个,html 4种展现样式:普通的html,svg,2D ca ...

随机推荐

  1. React 入门之路

    React React简介 是由Facebook公司推广的一套框架,已经应用instagram等产品 React就是为了提供应用程序性能而设计的一套框架 在angular中,对dom提供了一些指令,让 ...

  2. Linux进程的睡眠和唤醒

    1   Linux进程的睡眠和唤醒 在Linux中,仅等待CPU时间的进程称为就绪进程,它们被放置在一个运行队列中,一个就绪进程的状态标志位为TASK_RUNNING.一旦一个运行中的进程时间片用完, ...

  3. oracle12安装软件后安装数据库,然后需要自己配置监听

    oracle12安装软件后安装数据库,然后需要自己配置监听 没想到你是这样的oracle12: 不能同时安装软件和数据库,分别安装之后,\NETWORD\ADMIN\下面竟然没有listener.or ...

  4. 客户推广微信小程序的几种方法如下

    一.店面二维码推广 1.店铺门口张贴 2.餐桌.柜台张贴 3.展架.海报宣传展示 二.结合促销活动,宣传单页上印小程序二维码线下派发 三.餐厅送餐时附带点餐小卡片,印小程序二维码 四.首次扫码立送积分 ...

  5. $ is not defined

    $ is not defined 引入Jquery的顺序不正确,要把它放在第一个引入

  6. 利用AFNetworking框架去管理从聚合数据上面请求到的数据

    数据从JSON文档中读取处理的过程称为“解码”过程,即解析和读取过程,来看一下如果利用AFNetworking框架去管理从聚合数据上面请求到的数据. 一.下载并导入AFNetworking框架 这部分 ...

  7. PHP之面向对象学习

    1.类 Class lio{ Public Protect Private Function __constructor(){} } 2.类的实例化 <? php class lio{ //定义 ...

  8. 重读金典------高质量C编程指南(林锐)-------第七章 内存管理

    2015/12/10补充: 当我们需要给一个数组返回所赋的值的时候,我们需要传入指针的指针.当我们只需要一个值的时候,传入指针即可,或者引用也可以. 结构大致如下: char* p = (char*) ...

  9. pom.xml基础配置

    pom.xml基础配置: maven中,最让我迷惑的还是那一堆配置! 就拿这个属性配置来说: 我需要让整个项目统一字符集编码,就需要设定 <project.build.sourceEncodin ...

  10. centos7 安装rocketmq(quick start)

    Quick Start This quick start guide is a detailed instruction of setting up RocketMQ messaging system ...