Redis如何保证和数据库的数据一致性

Redis如何保证和数据库的数据一致性?

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

猜你喜欢

转载自blog.csdn.net/qq_42455262/article/details/128570238