在高并发应用中,单机的redis已无法满足需求,所以我们需对redis做集群处理。目前主要有两种方式实现:
1、通过Jedis操作Redis Cluster的模型可以参考Redis官网,具体如下:
<!-- 对象池配置 -->
<bean id="jedisItemPoolConfig" class="org.apache.commons.pool2.impl.GenericObjectPoolConfig">
<!-- 最大分配的对象数 -->
<property name="maxTotal" value="${redis.pool.maxActive}" />
<!-- 最小能够保持idel状态的对象数 -->
<property name="minIdle" value="${redis.pool.minIdle}" />
<!-- 最大能够保持idel状态的对象数 -->
<property name="maxIdle" value="${redis.pool.maxIdle}" />
<!-- 当池内没有返回对象时,最大等待时间 -->
<property name="maxWaitMillis" value="${redis.pool.maxWait}" />
<!-- 当调用borrow Object方法时,是否进行有效性检查 -->
<property name="testOnBorrow" value="${redis.pool.testOnBorrow}" />
<!-- 当调用return Object方法时,是否进行有效性检查 -->
<property name="testOnReturn" value="${redis.pool.testOnReturn}" />
</bean>
<!-- REDIS的连接池pool -->
<bean id="jedisItemCluster" class="redis.clients.jedis.JedisCluster">
<constructor-arg index="0">
<list>
<bean class="redis.clients.jedis.HostAndPort">
<constructor-arg index="0" value="${redis.item.host}" />
<constructor-arg index="1" value="${redis.item.port}" />
</bean>
</list>
</constructor-arg>
<constructor-arg index="1" ref="jedisItemPoolConfig" />
</bean>
2、通过spring-data-redis实现
<!-- 缓存管理器 -->
<bean id="cacheManager" class="org.yyy.auth.client.shiro.cache.RedisCacheManager"></bean>
<!-- redis序列化数据格式处理,这里自定义实现了org.springframework.data.redis.serializer.RedisSerializer<T>接口 -->
<bean id = "jedisSerializer" class = "org.yyy.auth.client.shiro.cache.FastJsonSerializer"></bean>
<!-- redis数据连接池 -->
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<!-- 最大分配的对象数 -->
<property name="maxTotal" value="${redis.pool.maxActive}" />
<!-- 最小能够保持IDLE状态的对象数 -->
<property name="minIdle" value="${redis.pool.minIdle}" />
<!-- 最大能够保持IDLE状态的对象数 -->
<property name="maxIdle" value="${redis.pool.maxIdle}" />
<!-- 当池内没有返回对象时,最大等待时间 -->
<property name="maxWaitMillis" value="${redis.pool.maxWait}" />
<!-- 当调用borrow Object方法时,是否进行有效性检查 -->
<property name="testOnBorrow" value="${redis.pool.testOnBorrow}" />
<!-- 当调用return Object方法时,是否进行有效性检查 -->
<property name="testOnReturn" value="${redis.pool.testOnReturn}" />
</bean>
<!-- redis集群配置 -->
<bean id="redisClusterConfiguration" class="org.springframework.data.redis.connection.RedisClusterConfiguration">
<property name="clusterNodes">
<set>
<bean class="org.springframework.data.redis.connection.RedisNode">
<constructor-arg name="host" value="${shiro.redis.host}" />
<constructor-arg name="port" value="${shiro.redis.port}" />
</bean>
</set>
</property>
</bean>
<!-- redis工厂 -->
<bean id = "jedisClusterRedisConnectionFactory" class = "org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
<constructor-arg name="clusterConfig" ref="redisClusterConfiguration"/>
<constructor-arg name="poolConfig" ref="jedisPoolConfig"/>
</bean>
<!-- redis模板 -->
<bean id = "userRedisTemplate" class = "org.springframework.data.redis.core.RedisTemplate">
<property name="keySerializer" ref = "jedisSerializer"/>
<property name="connectionFactory" ref ="jedisClusterRedisConnectionFactory" />
</bean>
参考文献:http://www.cnblogs.com/moonandstar08/p/5149585.html