为什么Redis中key会惊现“乱码”?
最近在做一个秒杀项目,过程中大量应用得到了redis。
而我在用ElasticJob进行数据化初始化到Redis数据库时发现这些key都出现了一段前缀“乱码”。
数据结构为Hash,可以观察到hashkey也带有前缀“乱码”
这究竟是怎么回事呢?原来问题出在这:
我是用的是RedisTemplate,而RedisTemplate会出现编码问题,需要自行配置,如果不想配置,可以使用StringRedisTemplate,因为StringRedisTemplate的源码中是有帮我们配置的,因此使用StringRedisTemplate即可完美解决“乱码”问题。
代码: 重点在12行
//让Spring扫描到
@Component
@Getter
@Setter
@Slf4j
public class MyInitSeckillProductsJob implements SimpleJob {
//从nacos取cron
@Value("${jobCron.initSeckillProduct}")
private String cron;
@Autowired
private SeckillProductFeignApi seckillProductFeignApi;
@Autowired//这里要用StringRedisTemplate
private StringRedisTemplate redisTemplate;
@Override
public void execute(ShardingContext shardingContext) {
doWork(shardingContext.getShardingParameter());
}
//shardingParameter 就是分片参数 time
public void doWork(String time) {
//key
String SeckillProductKey = JobRedisKey.SECKILL_PRODUCT_LIST.getRealKey(time);
String StockCountKey=JobRedisKey.SECKILL_STOCK_COUNT_HASH.getRealKey(time);
//1.先把之前的数据删除掉
redisTemplate.delete(SeckillProductKey);
//2.远程调用秒杀商品服务根据分片参数time查询出result
Result<List<SeckillProductVo>> result = seckillProductFeignApi.selectSeckillProductVoByTime(Integer.parseInt(time));
//对list进行判空
if (result != null && !result.hasError()) {
//从result中取出data
List<SeckillProductVo> data = result.getData();
if (data != null && data.size() > 0) {
for (SeckillProductVo seckillProductVo : data) {
//3.将Vo对象存到redis中
redisTemplate.opsForHash().put(SeckillProductKey,seckillProductVo.getId() + "", JSON.toJSONString(seckillProductVo));
//4.将秒秒杀商品库存存到redis中
redisTemplate.opsForHash().put(StockCountKey,seckillProductVo.getId()+"",seckillProductVo.getStockCount()+"");
log.info("今日秒杀商品数据初始化完成");
}
}
}
}
}
解决编码问题之后的效果:
最后如果想了解如何使用RedisTemplate配置请浏览:
Redis key 乱码问题(springboot)