`

redis主从

 
阅读更多

Memcached完全基于分布式集群,而Redis是Master-Slave,如果想把Reids,做成集群模式,无外乎多做几套Master-Slave,每套Master-Slave完成各自的容灾处理,通过Client工具,完成一致性哈希。

PS:Memcached是在Server端完成Sharding,Redis只能依靠各个Client做Sharding。可能会在Redis 3.0系列支持Server端Sharding。



保留前面的JedisPoolConfig,新增两个Redis的IP(redis1.ip,redis2.ip),完成两个JedisShardInfo实例,并将其丢进List中:



Java代码
JedisShardInfo jedisShardInfo1 = new JedisShardInfo(
                bundle.getString("redis1.ip"), Integer.valueOf(bundle                     .getString("redis.port")));
JedisShardInfo jedisShardInfo2 = new JedisShardInfo(
                bundle.getString("redis2.ip"), Integer.valueOf(bundle                     .getString("redis.port")));

List<JedisShardInfo> list = new LinkedList<JedisShardInfo>();
list.add(jedisShardInfo1);
list.add(jedisShardInfo2);



初始化ShardedJedisPool代替JedisPool:



Java代码
ShardedJedisPool pool = new ShardedJedisPool(config, list);



改由ShardedJedis,获取Jedis对象:



Java代码
// 从池中获取一个Jedis对象
ShardedJedis jedis = pool.getResource();
String keys = "name";
String value = "snowolf";
// 删数据
jedis.del(keys);
// 存数据
jedis.set(keys, value);
// 取数据
String v = jedis.get(keys);

System.out.println(v);

// 释放对象池
pool.returnResource(jedis);


四、Spring封装参考
Ok,完成上述代码足够完成简单任务,如果有必要,可以用Spring封装初始化:



Xml代码
<context:property-placeholder location="classpath:redis.properties" />
<bean
    id="jedisPoolConfig"
    class="redis.clients.jedis.JedisPoolConfig"
>
    <property
      name="maxActive"
      value="${redis.pool.maxActive}" />
    <property
      name="maxIdle"
      value="${redis.pool.maxIdle}" />
    <property
      name="maxWait"
      value="${redis.pool.maxWait}" />
    <property
      name="testOnBorrow"
      value="${redis.pool.testOnBorrow}" />
</bean>
<bean
    id="shardedJedisPool"
    class="redis.clients.jedis.ShardedJedisPool"
>
    <constructor-arg
      index="0"
      ref="jedisPoolConfig" />
    <constructor-arg index="1">
      <list>
            <bean class="redis.clients.jedis.JedisShardInfo">
                <constructor-arg
                  index="0"
                  value="${redis1.ip}" />
                <constructor-arg
                  index="1"
                  value="${redis.port}"
                  type="int" />
            </bean>
            <bean class="redis.clients.jedis.JedisShardInfo">
                <constructor-arg
                  index="0"
                  value="${redis2.ip}" />
                <constructor-arg
                  index="1"
                  value="${redis.port}"
                  type="int" />
            </bean>
      </list>
    </constructor-arg>
</bean>
view plaincopy
<context:property-placeholder location="classpath:redis.properties" />
<bean
    id="jedisPoolConfig"
    class="redis.clients.jedis.JedisPoolConfig"
>
    <property
      name="maxActive"
      value="${redis.pool.maxActive}" />
    <property
      name="maxIdle"
      value="${redis.pool.maxIdle}" />
    <property
      name="maxWait"
      value="${redis.pool.maxWait}" />
    <property
      name="testOnBorrow"
      value="${redis.pool.testOnBorrow}" />
</bean>
<bean
    id="shardedJedisPool"
    class="redis.clients.jedis.ShardedJedisPool"
>
    <constructor-arg
      index="0"
      ref="jedisPoolConfig" />
    <constructor-arg index="1">
      <list>
            <bean class="redis.clients.jedis.JedisShardInfo">
                <constructor-arg
                  index="0"
                  value="${redis1.ip}" />
                <constructor-arg
                  index="1"
                  value="${redis.port}"
                  type="int" />
            </bean>
            <bean class="redis.clients.jedis.JedisShardInfo">
                <constructor-arg
                  index="0"
                  value="${redis2.ip}" />
                <constructor-arg
                  index="1"
                  value="${redis.port}"
                  type="int" />
            </bean>
      </list>
    </constructor-arg>
</bean>


代码可以更简洁一些:



Java代码
private ApplicationContext app;
private ShardedJedisPool pool;

@Before
public void before() throws Exception {
    app = new ClassPathXmlApplicationContext("applicationContext.xml");
    pool = (ShardedJedisPool) app.getBean("shardedJedisPool");
}

@Test
public void test() {

    // 从池中获取一个Jedis对象
    ShardedJedis jedis = pool.getResource();
    String keys = "name";
    String value = "snowolf";
    // 删数据
    jedis.del(keys);
    // 存数据
    jedis.set(keys, value);
    // 取数据
    String v = jedis.get(keys);

    System.out.println(v);

    // 释放对象池
    pool.returnResource(jedis);

    assertEquals(value, v);
}

当然,Spring提供了对于Redis的专门支持:spring-data-redis,以后有机会再深入研究。

分享到:
评论

相关推荐

    redis主从配置及通过keepalived实现redis自动切换

    Redis 主从配置及通过 Keepalived 实现 Redis 自动切换 标题:Redis 主从配置及通过 Keepalived 实现 Redis 自动切换 描述: Redis 主从配置及通过 Keepalived 实现 Redis 自动切换常用命令及故障分析 标签:...

    Redis主从复制和集群配置

    ### Redis主从复制和集群配置详解 #### 一、Redis主从复制原理及配置 **1.1 概述** Redis的主从复制机制是一种重要的数据同步方式,它支持一个或多个从数据库(slave)与主数据库(master)之间进行数据同步。其中,...

    redis 主从服务器配置

    Redis 主从服务器配置 Redis 作为一个 NoSQL 型数据库,具有高性能、高扩展性和高可靠性的特点。在本文中,我们将详细介绍如何配置 Redis 主从服务器,以实现高可用性和高性能的缓存系统。 Redis 概述 Redis 是一...

    redis 主从配置demo

    本教程将通过一个简单的示例介绍如何配置 Redis 主从。 一、Redis 主从复制的基本原理 在 Redis 的主从复制中,主节点负责接收客户端的写请求,并将修改操作(命令)传播到所有从节点。从节点则定期同步主节点的...

    redis主从复制集群

    ### Redis 主从复制集群知识点详解 #### 一、Redis 主从复制概述 Redis 主从复制是一种数据冗余机制,主要用于实现读写分离、负载均衡以及数据备份等目的。通过搭建主从复制集群,可以有效避免单点故障问题,并且...

    Redis主从复制以及主从复制技术原理.docx

    Redis 主从复制技术原理 概述 Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。Redis 主从复制是指将一台 Redis 服务器的数据,复制到...

    redis主从备份双机热备集群简洁配置方式

    redis主从备份双机热备集群简洁配置方式,主要配置redis.conf文件和sentinel.conf文件,可以实现主从自动切换,宕机也不怕

    spring cache + redis 主从

    总结以上步骤,完成Redis主从配置与高可用哨兵模式的搭建,再整合Spring Cache,可以使应用程序在保证性能的同时具备高可用性。需要注意的是,所有的配置操作都需要在保证安全的前提下进行,避免生产环境下的操作...

    docker-compose redis主从哨兵 redis多节点高可用 redis集群高可用

    1. **Redis主从复制**:这是基础的高可用方案,通过将数据实时同步到一个或多个从节点,即使主节点故障,从节点也能无缝接管服务。在Docker Compose文件中,我们需要定义三个服务,一个为主节点,两个为从节点,并...

    LAMP架构+Redis主从复制.docx

    LAMP架构+Redis主从复制 本文档主要介绍了LAMP架构的安装和配置,以及Redis主从复制的设置。LAMP架构是指Linux操作系统、Apache HTTP服务器、MySQL数据库和PHP编程语言的组合,而Redis则是一个开源的、基于内存的...

    redis常用命令,redis配置文件,redis持久化,redis事务,redis主从复制,jedis的使用

    下面是对 Redis 的常用命令、配置文件、持久化、事务、主从复制、Jedis 使用的详细讲解。 Redis 常用命令 Redis 提供了很多有用的命令来管理和操作数据。下面是一些常用的 Redis 命令: * SET key value:设置...

    redis 主从切换 实现HA 的方法和工具

    Redis主从复制是其HA的基础,它允许一个Redis实例(主节点)的数据被多个实例(从节点)实时同步。当主节点出现问题时,可以快速切换到一个从节点继续提供服务。以下是主从复制的基本步骤: 1. 配置主节点:在主...

    redis主从复制活动图

    描述redis主从复制的过程中的各种细节,包括各个阶段所使用的事件处理函数

    第02篇:Redis主从复制getshell1

    1、生成恶意.so文件,下载RedisModules-ExecuteCommand使用make编译即可生成 1、监听本地1234端口 2、将Redis服务器设置

    redis主从模式修改的配置文件.zip

    Redis 是一个高性能的键值数据库,...下载提供的"redis主从模式修改的配置文件.zip",解压后根据实际情况调整配置,再分别启动主从节点,即可实现数据的实时同步。记得在实践中不断学习和优化,以满足实际业务需求。

    Redis主从搭建

    ### Redis主从搭建知识点 #### 一、Redis单机安装部署 在进行Redis主从配置之前,首先需要完成单个Redis实例的安装部署工作。以下是详细的步骤: 1. **准备安装包**: - 将`redis-2.8.6.tar.gz`安装包拷贝到指定...

    Redis主从复制+哨兵配置手册.docx

    Redis 主从复制和哨兵配置手册 Redis 主从复制是一种高可用性解决方案,可以确保数据的安全和可靠性。在这个手册中,我们将详细介绍 Redis 主从复制的配置和哨兵的配置。 环境准备 在开始配置 Redis 主从复制之前...

    通过SSRF操作Redis主从复制写Webshell_R3start1

    1.使用 DICT 协议添加一条测试记录 2.设置保存路径 3.设置保存文件名 4.保存 1.连接远程主服务器 2.设置保存路径 3.设置保存文件名 4.保存

    windows redis 主从集群实例加哨兵集群

    Windows Redis主从集群及哨兵集群的搭建是提高Redis服务的可用性和数据安全性的重要手段。下面将详细介绍这两个概念以及如何在Windows环境中实现。 1. Redis主从集群: 主从复制是Redis提供的一种数据备份和故障...

Global site tag (gtag.js) - Google Analytics