Redis在spring中的几种常用配置方法

单机模式的redis就不说了。
一.首先贴一下多机分片的配置

<bean id="shardedJedisPool" class="redis.clients.jedis.ShardedJedisPool" destroy-method="destroy">
        <constructor-arg ref="jedisPoolConfig"/> 
        <constructor-arg>
            <list> 
                <!-- 配置分片实例 -->
                <bean class="redis.clients.jedis.JedisShardInfo"> 
                    <constructor-arg index="0" value="127.0.0.1"/>
                    <constructor-arg index="1" value="6379"/>
                    <constructor-arg index="2" value="instance:01"/>
                </bean>
            </list>
        </constructor-arg>
     </bean>

     <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="1000"/> 
        <property name="maxIdle" value="10"/> 
        <property name="minIdle" value="1"/>
        <property name="maxWaitMillis" value="30000"/> 
        <property name="testOnBorrow" value="true"/> 
        <property name="testOnReturn" value="true"/> 
        <property name="testWhileIdle" value="true"/>
    </bean>

使用的时候直接通过shardedJedisPool获得shardedJedis实例,最后记得返还连接

二.当我们需要HA提供监控和主从切换的时候或者可以参考Spring-session的连接方案,这种方案我们首先假设不分片。

<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="35"/>
        <property name="maxIdle" value="1000"/>
        <property name="minIdle" value="100"/>
        <property name="maxWaitMillis" value="1000"/>
        <property name="testOnBorrow" value="true"/>
        <property name="testOnReturn" value="true"/>
        <property name="testWhileIdle" value="false"/> 
    </bean> 

    <bean id="redisSentinelConfiguration" class="org.springframework.data.redis.connection.RedisSentinelConfiguration">
       <property name="master">
            <bean class="org.springframework.data.redis.connection.RedisNode">
                <property name="name" value="def_master"></property>
            </bean>
       </property>
       <property name="sentinels">
           <set>
               <bean class="org.springframework.data.redis.connection.RedisNode">                   
                    <constructor-arg name="host" value="127.0.0.1"/>
                    <constructor-arg name="port" value="26379"/>               
               </bean> 
           </set>
       </property>
    </bean>

    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <constructor-arg name="sentinelConfig" ref="redisSentinelConfiguration"/>
        <constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
    </bean>

    <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
        <property name="connectionFactory" ref="jedisConnectionFactory"/>
    </bean>

但若使用了数据分片-sharing,数据被平均分布到多个不同的实例上,每个实例以主从结构部署,Jedis没有提供基于Sentinel的ShardedJedisPool,也就是说在多个分片中,如果其中一个分片发生主从切换,应用所使用的ShardedJedisPool无法获得通知,所有对那个分片的操作将会失败。

所以如果需要一种既可以实现多机配置,每片均为主从结构,sentinel统一进行监控,并且从ShardedJedisPool获取ShardedJedis实例,可以参考如下配置

 <bean id="shardedJedisPool" class="com.util.config.ShardedJedisSentinelPool">
        <constructor-arg index="0" ref="jedisPoolConfig" />
        <constructor-arg index="1">
            <list>
                <value>def_master</value>
            </list>
        </constructor-arg>
        <constructor-arg index="2">
            <set>
                <value>127.0.0.1:26379</value>
            </set>
        </constructor-arg>
    </bean>

    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="200" />
        <property name="maxIdle" value="100" />
        <property name="maxWaitMillis" value="5000" />
        <property name="testOnBorrow" value="true" />
    </bean>

贴一下ShardedJedisSentinelPool的项目地址 https://github.com/warmbreeze/sharded-jedis-sentinel-pool
关于该项目请参考原贴 http://www.tuicool.com/articles/naeEJbv

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值