V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
shanghai1943
V2EX  ›  程序员

你们的缓存一般设置多长时间

  •  
  •   shanghai1943 · 2023-05-24 11:39:42 +08:00 · 1289 次点击
    这是一个创建于 578 天前的主题,其中的信息可能已经有所发展或是发生改变。

    目前自己的缓存设置时间比较短,都是 5 分钟 10 分钟这种,缓存没了再读取数据库然后重新写入缓存。

    设置这么短的目的是担心万一某些场景更新数据后没有删除缓存,会导致缓存里的数据准确性持续太久,所以设置短一点。当然大部分情况下其实都能做到更新后删除缓存,但是一般是没有意识去保证在事务提交成功后删除缓存,而是执行了更新语句之后就执行删除缓存的代码了,所以理论上可能会存在删除缓存后在事务提交成功前有可能缓存又被重新建立了,导致缓存可能是不够准确的。

    想问问大家都是怎么做的。

    数据库:MySQL 缓存:Redis

    2 条回复    2023-05-24 13:47:19 +08:00
    potatowish
        1
    potatowish  
       2023-05-24 12:35:13 +08:00 via iPhone   ❤️ 2
    可以用 CDC 中间件订阅 binlog 日志,Canal 、Debezium 等
    Sendya
        2
    Sendya  
       2023-05-24 13:47:19 +08:00 via Android   ❤️ 1
    缓存时间基本跟着业务形态走的。
    如果担心缓存准确性,可以在有数据变更的时候 mq 广播一下,让缓存 purge 重载。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2529 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 03:56 · PVG 11:56 · LAX 19:56 · JFK 22:56
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.