Redis如何保证和数据库的数据一致性?
- 先更新数据库,再更新Redis,如果Reids更新失败,任然可能出现数据不一致的情况
- 先删除Redis中的缓存数据,再更新数据库,再次查询将数据库中的数据添加到Reids缓存中,这种方案虽然能解决方案1中的问题,但是在高并发的情况下性能会非常低,而且任然会出现数据不一致的问题,
举个例子:
线程1删除了Reids缓存数据,正在更新数据库,此时另外一个查询在查数据库,那么老数据又会被更新到Reids中去。 - 延迟双删,步骤是先删除Redis缓存中的数据,再更新数据库中的数据,延迟几毫秒再删除Redis中的数据,这样就算是更新数据库的中途,查询到了老数据把它写入了Redis也不会影响数据的一致性。