单机模式的redis就不说了。
一.首先贴一下多机分片的配置
<bean id="shardedJedisPool" class="" destroy-method="destroy">
<constructor-arg ref="jedisPoolConfig"/>
<constructor-arg>
<list>
<!-- 配置分片实例 -->
<bean class="">
<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="">
<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="">
<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="">
<property name="master">
<bean class="">
<property name="name" value="def_master"></property>
</bean>
</property>
<property name="sentinels">
<set>
<bean class="">
<constructor-arg name="host" value="127.0.0.1"/>
<constructor-arg name="port" value="26379"/>
</bean>
</set>
</property>
</bean>
<bean id="jedisConnectionFactory" class="">
<constructor-arg name="sentinelConfig" ref="redisSentinelConfiguration"/>
<constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
</bean>
<bean id="redisTemplate" class="">
<property name="connectionFactory" ref="jedisConnectionFactory"/>
</bean>
但若使用了数据分片-sharing,数据被平均分布到多个不同的实例上,每个实例以主从结构部署,Jedis没有提供基于Sentinel的ShardedJedisPool,也就是说在多个分片中,如果其中一个分片发生主从切换,应用所使用的ShardedJedisPool无法获得通知,所有对那个分片的操作将会失败。
所以如果需要一种既可以实现多机配置,每片均为主从结构,sentinel统一进行监控,并且从ShardedJedisPool获取ShardedJedis实例,可以参考如下配置
<bean id="shardedJedisPool" class="">
<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="">
<property name="maxTotal" value="200" />
<property name="maxIdle" value="100" />
<property name="maxWaitMillis" value="5000" />
<property name="testOnBorrow" value="true" />
</bean>
贴一下ShardedJedisSentinelPool的项目地址 /warmbreeze/sharded-jedis-sentinel-pool
关于该项目请参考原贴 /articles/naeEJbv