一. 先删redis,再修改数据库
数据不一致的情况:
一、 线程A修改数据时,需先执行删除缓存操作
二、其他线程只要在线程A删除缓存和执行update期间,查询数据库得到了旧的数据,此时就有极大的概率会出现数据不一致的情况。
二. 先修改数据库,再删redis(相比先删缓存可能出现数据不一致的概率要小)
数据不一致的情况:
一、 线程A读取数据,刚好缓存失效了,去查询数据库数据,刚要执行放入redis缓存时,CPU发生上下文切换,线程A暂时得不到执行
二、此时线程B修改数据,执行update商品操作,然后删除缓存
三、线程A执行时,将之前查询到的旧的数据存到redis缓存中,此时就会出现redis和数据库的数据不一致的情况。
三.延时双删
在对数据库操作前后各进行一次删除缓存key的操作,设置合理的超时时间
- 先删除redis
- 再修改数据库
- 等待一段时间(几百毫秒)后再次删除redis
public void write( String key,