问题
你们的 Redis 使用的是淘汰缓存还是更新缓存,这两者有什么区别?请详细说明
答案解析
首先,需要了解到在 Redis 中,缓存操作的读与写究竟是一个怎么样的流程
缓存操作流程-读
在添加 Redis 的之后,后端的查询(读)流程是:
-
请求后端服务。
-
经过逻辑处理后,先去缓存(Redis)中进行查询,如果查到,则直接返回。
-
如果没有查到信息,则直接向数据库进行查询,查询到之后,数据库会讲数据信息同步到缓存(Redis)中,以便下次查询。
缓存操作流程-写
在使用 Redis 之后,缓存的更新通常来说有两种方案:
-
淘汰缓存
-
更新缓存
什么是淘汰缓存
淘汰缓存的过程为:
-
更新数据库后,直接将缓存中的记录删除。
-
查询数据时,就无法从缓存中获取,只能从数据库获取。从数据库获取之后,同步更新缓存。
-
第二次查询数据时,即可从缓存中读取到最新的数据。
淘汰缓存的优点与缺点:
-
优点:操作简单,性能比较好
-
缺点:淘汰之后下一次请求就会读取数据库,至少会出现一个 cache miss。
什么是更新缓存
更新缓存的过程为:
-
由缓存的调用者,在更新数据库的同时更新缓存。
-
查询数据时,即可从缓存中读取到最新的数据。
淘汰缓存的优点与缺点:
-
优点:基本不会出现cache miss的情况。
-
缺点:每次更新数据库都更新缓存,比较影响性能。
总结:在实际工作中,具体使用淘汰缓存还是更新缓存应该视情况而定。大部分情况,修改数据成本会高于增加一次cache miss,因此应该选用淘汰缓存。