如何使用 Redis 跟踪短期和长期的移动用户历史记录

How to use Redis to track mobile-user-history for short term and long term

我们的移动应用程序跟踪用户历史记录(历史事件预定义了操作和日期)

报告用户历史的每个移动设备都可以检索它。

我虽然在 Redis 上使用最新的历史记录(比如说 100 条记录)进行快速检索,并在 100 条记录后将旧数据移动到某个数据源。

  1. 你认为 Redis 是否适合短期历史检索?
  2. 您会使用哪个数据源来保存最早的历史记录以备检索?

根据您的经验得出的其他想法?谢谢。

是的,Redis 是短期历史行为的绝佳选择。 LIST 是一个很好看的数据结构:

  1. 快速插入有序数据(LPUSH for O(1)
  2. 快速 select(LRANGE 对于 O(S+N)
  3. 低内存消耗(实际上是 Redis 中最低的 - 每个列表项仅 21 字节开销)

您还可以使用某种 cron 作业来获取旧数据并将其插入到 SQL 中,例如数据库。使用 LUA scrpting 获取日志尾部:

local ret = {}
while tonumber(redis.call('llen', KEYS[1])) > tonumber(ARGV[1]) do
   table.insert(ret, redis.call('rpop', KEYS[1]))
end
return ret

其中 KEY 是您的 LIST 键,第一个参数是要处理的尾部大小。这个 LUA 脚本自动切断(和 return)你所有的日志条目超过 ARGV1。下一步很简单 foreach by list 并插入到 SQL 数据库。

虽然用户想要获取他的所有历史记录(在伪代码中,require 变量是用户查询的总记录数):

ret = redis.call('LRANGE', 'myKey', 0, require)
require = require - length(ret)
if (require > 0) {
    ret += db.query('SELECT ... LIMIT ' + require)
}