一个用户搜索历史记录的实现问题

2021-03-05 11:14:59 +08:00
 mamasan

App 每个用户每次搜索的内容需要到服务器(方便切换设备登录帐号同步). 目标用户 50 万, 每用户 100 个搜索记录.

  1. 使用 redis 去保存. 用户 id 做 key, 搜索记录用 zset(去重, 按时间排序)
  2. 将所有的搜索记录保存进 es, es 使用用户 id 做 hash 分片.

想请问下, 那种方案比较好呢? 或者是否有其他的方案呢? 用 redis 主要是担心,及时开了持久化, 是否会有用户数据丢失的问题. 用 es 怎么解决用户先搜索'A', 再搜索'B', 第三次再搜索'A', 这个时候, 历史记录只显示'A', 'B', 而不是'A', 'B', 'A'的问题

794 次点击
所在节点    问与答
1 条回复
wakzz
2021-03-05 14:52:24 +08:00
存 es,并且由自己指定记录 ID,例如以用户 id+搜索内容的 md5 做 id,来实现防重复的情况。

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

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

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

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

© 2021 V2EX