Redis在spring中的几种常用配置方法
2016-09-02 14:11
567 查看
单机模式的redis就不说了。
一.首先贴一下多机分片的配置
使用的时候直接通过shardedJedisPool获得shardedJedis实例,最后记得返还连接
二.当我们需要HA提供监控和主从切换的时候或者可以参考Spring-session的连接方案,这种方案我们首先假设不分片。
但若使用了数据分片-sharing,数据被平均分布到多个不同的实例上,每个实例以主从结构部署,Jedis没有提供基于Sentinel的ShardedJedisPool,也就是说在多个分片中,如果其中一个分片发生主从切换,应用所使用的ShardedJedisPool无法获得通知,所有对那个分片的操作将会失败。
所以如果需要一种既可以实现多机配置,每片均为主从结构,sentinel统一进行监控,并且从ShardedJedisPool获取ShardedJedis实例,可以参考如下配置
贴一下ShardedJedisSentinelPool的项目地址 https://github.com/warmbreeze/sharded-jedis-sentinel-pool
关于该项目请参考原贴 http://www.tuicool.com/articles/naeEJbv
一.首先贴一下多机分片的配置
<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"> < 8ca4 span class="hljs-tag"><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
相关文章推荐
- spring AOP配置的几种方法
- 加载spring配置文件的常用三种方法
- Spring中数据源和数据库连接池配置的几种方法
- Spring几种数据源的配置方法
- Spring的几种配置方法
- Spring配置sessionFactory的几种常用方式
- Spring 中数据源和数据库连接池配置的几种方法
- 读取Spring的配置文件applicationContext.xml几种方法
- 几种常用的webservice客户端和spring集成的方法
- Struts ,Hibernate ,Spring 常用整合配置方法.
- spring中配置数据源的几种方法
- Spring加载配置文件的几种方法
- 读取Spring的配置文件applicationContext.xml几种方法
- Spring中数据源和数据库连接池配置的几种方法
- 加载spring配置文件的常用三种方法
- Spring中数据源和数据库连接池配置的几种方法
- Spring中数据源和数据库连接池配置的几种方法
- Web项目中加载Spring配置的常用方法
- apache配置多个站点的几种常用方法
- 几种常用的xml配置,Spring,Struts,Mybatis,sitemesh