最近一直在老家远程办公,微信突然响了下,有同事说遇到了一个奇怪的问题,让我帮忙看下。
现象就是标题所说的缓存获取不到的问题,我一听感觉这个问题挺有意思的,决定一探究竟。
下面给出部分代码还原下案发现场:
@CreateCache(name = “demo”, expire = 600)
private Cache<String, ThirdPartyEventResponse> cache;
@Test
public void test() {
ThirdPartyEventResponse eventResponse = new ThirdPartyEventResponse();
eventResponse.setTicketCategories(Arrays.asList(ticketCategoryResponse));
// 省略 …
// 添加
cache.put(DisChannelType.PIAONIU.getValue(), eventResponse);
// 获取
ThirdPartyEventResponse resp = cache.get(DisChannelType.PIAONIU.getValue());
}
复制代码Put之后马上Get,居然获取不到值。这就有点匪夷所思了,我们来好好排查下。
首先过期时间为600秒,肯定不是刚保存就过期了的原因。
然后去Redis中查看到底有没有Put进去,发现数据在Redis中已经存在了,证明插入没问题。
只有使出终极必杀器了,那就是debug源码。
通过get方法一直往下看,最终到了RedisCache里面。
然后在这里打个断点,看看到底有没有获取到Redis中的值