spring中redis 配置的不对
如下配置:
-
<!--redis配置-->
-
<bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
-
<property name="maxIdle" value="${redis.maxIdle}" />
-
<property name="maxTotal" value="${redis.maxActive}" />
-
<property name="maxWaitMillis" value="${redis.maxWait}" />
-
<property name="testOnBorrow" value="${redis.testOnBorrow}" />
-
</bean>
-
<!--spring redis配置-->
-
<bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"
-
p:host-name="${redis.host}"
-
p:port="${redis.port}"
-
p:password="${redis.pass}"
-
p:pool-config-ref="poolConfig"/>
-
<!--下面是配置的关键-->
-
<bean id="stringRedisSerializer"
-
class="org.springframework.data.redis.serializer.StringRedisSerializer" />
-
<!--下面可以单独使用,可以设置生存时间-->
-
<bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"
-
p:connectionFactory-ref="connectionFactory" p:keySerializer-ref="stringRedisSerializer"
-
p:hashKeySerializer-ref="stringRedisSerializer"
-
p:hashValueSerializer-ref="stringRedisSerializer" />
-
<!--下面可以单独使用,可以设置生存时间-->
-
<bean id="stringRedisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate"
-
p:connectionFactory-ref="connectionFactory" />
使用:可以封装到dao中,也可以通过spring上下文去获取RedisTemplate或者 stringRedisTemplate来使用。举例:
-
redisTemplate.expire("redisobject", 30, TimeUnit.SECONDS);
-
stringRedisTemplate.expire("redis", 30, TimeUnit.SECONDS);
-
//注意保证使用的key是存在的
-
//redisTemplate.expire(key,timeout,timeunit);
-
//参数说明 key 需要设置的key timeout:key的生存时间 timeuint:时间单位(小时,分钟,秒……)
-
//可以用 ttl key 命令查看该key的生存时间
注意:以上的方法只适用于key对应的值不再更新的问题,如果遇到包含生命周期的值需要更新的情景就不适用了,因为set 方法会丢失该key的生存时间,变成永久有效的。
比如以下场景:一天内限制某个用户只能访问2000次服务api。
怎么做呢?把值放进hash散列里,更新hash散列不会有问题。(实际上INCR,LPUSH,HSET,ZREM指令都不会影响key的生存时间,当然list,set都是可行的,根据自己的场景选择合适的数据结构)
下面简单列一下代码,使用spring-data(不推荐使用,封装的太繁琐,不如直接使用jedis,然后写个工具类做下简单封装)
-
@Override//给指定的key设定生存时间
-
public boolean setKeyLifeTime(String key,long lifetime,TimeUnit unit){
-
boolean result=redisTemplate.expire(key, lifetime, unit);
-
return result;
-
}
-
@Override//放入redis,更新也使用这个方法,前提key要存在
-
public void setHash(String hashName, Object key, Object value) {
-
redisTemplate.opsForHash().put(hashName, key, value);
-
}
-
@Override//取值
-
public Object getHash(String hashName, Object key) {
-
return redisTemplate.opsForHash().get(hashName, key);
-
}
转载于:https://my.oschina.net/mifans/blog/792446