缓存小技巧--key的关联性

本文探讨了在复杂模型中实现缓存一致性的挑战及解决方案。针对多个键关联同一数据的情况,提出了通过键间关联来维护数据一致性的方法。

如果我们对一个比较复杂的模型做cache,会有如下需求:

1. 利用多个key去查询这一模型的cache

2. 继而要求可以利用多个key去删除cache时

 

如果按照最简单的模型,每个key对应一个cache数据,这样当某一个key对应cache中的数据变动时,另外一个key对应的cache数据必定成为脏数据。

举例:key1->cacheObject,key2->cacheObject,当put(key1,cacheObject)时,key2对应的数据必定是脏数据;或者remove(key1)时,key2对应的cacheObject也还是会存在的,也是脏数据。

 

于是,有个办法,就是把多个key关联起来,通过key之间的关联,达到数据一致性的目的。

 

我们的模型是这样的:

key1->key2,key2->cacheObject,在实际的程序中

存数据:put(key1,key2);put(key2,cacheObject)

查数据:key2=get(key1);cacheObject=get(key2);

删数据:key2=get(key1);remove(key2);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值