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

2023-08-28 21:47:51 +08:00
 ben548
场景:有几十万个的 IM 聊天窗口(每个聊天窗口有一个属于自己的 IM_id ),客户端每 30s 根据 IM_id 批量拉一次最新的 6 条聊天数据,已知最新的 6 条数据已经保存到了 redis 中 zset 数据结构中,怎么利用 localcache 保障这个接口的高性能?
1284 次点击
所在节点    Go 编程语言
2 条回复
s4w
2023-08-29 01:04:43 +08:00
维护一个 LRU 本地缓存,后台起个协程定时更新本地缓存。本地缓存失效再回源 redis ,更新本地缓存。不过感觉本地缓存一般是为了保存热点数据,读多写少,个人感觉这个 IM 场景的例子举得不太好,这里不适合用本地缓存。
guonaihong
2023-08-29 22:15:12 +08:00
你们 im 的 id 不是单调递增的吗?如果的是话 server_max - client_max 如果等于 0 ,说明没有消息更新就不需要拉。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/969007

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX