public void batchSetBaseArea(List<BaseArea> dataList) {
redisTemplate.executePipelined(new RedisCallback<List<Object>>() {
@Override
public List<Object> doInRedis(RedisConnection connection) throws DataAccessException {
// 4.缓存地区到一个map
String mapKey = CacheBaseAreaConsts.BASE_AREA_ALL_MAP_CACHE_KEY;
Map<String, BaseArea> areaMap = new HashMap<String, BaseArea>();
StringRedisSerializer srs = (StringRedisSerializer) redisTemplate.getKeySerializer(); //序列化key的
JdkSerializationRedisSerializer jrs = (JdkSerializationRedisSerializer) redisTemplate.getValueSerializer(); //序列化value的
int i = 0;
for (BaseArea baseArea : dataList) {
byte[] value = jrs.serialize(baseArea);
// 1.根据id缓存
String idKey = CacheBaseAreaConsts.BASE_AREA_ID_CACHE_KEY + baseArea.getAreaId();
connection.set(srs.serialize(idKey), value);
// 2.根据code缓存
String codeKey = CacheBaseAreaConsts.BASE_AREA_CODE_CACHE_KEY + baseArea.getAreaCode();
connection.set(srs.serialize(codeKey), value);
// 3.根据nationalCode缓存
String nationalKey = CacheBaseAreaConsts.BASE_AREA_NATIONAL_CACHE_KEY + baseArea.getNationalCode();
connection.set(srs.serialize(nationalKey), value);
areaMap.put(baseArea.getAreaCode(), baseArea);
i++;
logger.debug("缓存主观进度========{}/{}", i, dataList.size());
}
connection.set(srs.serialize(mapKey), jrs.serialize(areaMap));
return null;
}
});
}
设置过期时间:
redisUtil.expire(key, 300) //5分钟后过期,单位秒;
/**
* 设置redis 固定时间自动消除
*
* @param key
* @param time
*/
public void expire(String key, long time) {
redisTemplate.expire(key, time, TimeUnit.SECONDS);// 以秒为单位
}