一、spring-redis配置
xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
如上,在shardedJedisPool中增加多个redis分片
二、代码实现
import javax.inject.Inject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import com.iflashbuy.base.util.JsonUtil;
import com.iflashbuy.base.util.StringUtil;
import redis.clients.jedis.ShardedJedis;
import redis.clients.jedis.ShardedJedisPool;
@Component
public class RedisOperator {
private static final Logger log = LoggerFactory.getLogger(RedisOperator.class);
@Inject
public ShardedJedisPool shardedJedisPool;
public void set(String key, Object obj) {
String jsonStr = "";
if (obj instanceof String) {
jsonStr = (String) obj;
} else {
jsonStr = JsonUtil.objectToJsonStr(obj);
}
ShardedJedis jedis = shardedJedisPool.getResource();
jedis.set(key, jsonStr);
}
public T get(String key, Class clazz) {
ShardedJedis jedis = shardedJedisPool.getResource();
String jsonStr = jedis.get(key);
if (StringUtil.isNotEmpty(jsonStr)) {
try {
return (T) JsonUtil.formJson(jsonStr, clazz);
} catch (Exception e) {
log.error("joson转为对象失败:" + e);
return null;
}
} else {
return null;
}
}
}