V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
ben548
V2EX  ›  Go 编程语言

批量查询下,怎么利用 localcache 提高接口的性能?

  •  
  •   ben548 · 2023-08-28 21:47:51 +08:00 · 1273 次点击
    这是一个创建于 448 天前的主题,其中的信息可能已经有所发展或是发生改变。
    场景:有几十万个的 IM 聊天窗口(每个聊天窗口有一个属于自己的 IM_id ),客户端每 30s 根据 IM_id 批量拉一次最新的 6 条聊天数据,已知最新的 6 条数据已经保存到了 redis 中 zset 数据结构中,怎么利用 localcache 保障这个接口的高性能?
    2 条回复    2023-08-29 22:15:12 +08:00
    s4w
        1
    s4w  
       2023-08-29 01:04:43 +08:00 via iPhone
    维护一个 LRU 本地缓存,后台起个协程定时更新本地缓存。本地缓存失效再回源 redis ,更新本地缓存。不过感觉本地缓存一般是为了保存热点数据,读多写少,个人感觉这个 IM 场景的例子举得不太好,这里不适合用本地缓存。
    guonaihong
        2
    guonaihong  
       2023-08-29 22:15:12 +08:00
    你们 im 的 id 不是单调递增的吗?如果的是话 server_max - client_max 如果等于 0 ,说明没有消息更新就不需要拉。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1314 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 17:46 · PVG 01:46 · LAX 09:46 · JFK 12:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.