如何使用 Redis 跟踪短期和长期的移动用户历史记录
How to use Redis to track mobile-user-history for short term and long term
我们的移动应用程序跟踪用户历史记录(历史事件预定义了操作和日期)
报告用户历史的每个移动设备都可以检索它。
我虽然在 Redis 上使用最新的历史记录(比如说 100 条记录)进行快速检索,并在 100 条记录后将旧数据移动到某个数据源。
- 你认为 Redis 是否适合短期历史检索?
- 您会使用哪个数据源来保存最早的历史记录以备检索?
根据您的经验得出的其他想法?谢谢。
是的,Redis 是短期历史行为的绝佳选择。 LIST 是一个很好看的数据结构:
您还可以使用某种 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)
}
我们的移动应用程序跟踪用户历史记录(历史事件预定义了操作和日期)
报告用户历史的每个移动设备都可以检索它。
我虽然在 Redis 上使用最新的历史记录(比如说 100 条记录)进行快速检索,并在 100 条记录后将旧数据移动到某个数据源。
- 你认为 Redis 是否适合短期历史检索?
- 您会使用哪个数据源来保存最早的历史记录以备检索?
根据您的经验得出的其他想法?谢谢。
是的,Redis 是短期历史行为的绝佳选择。 LIST 是一个很好看的数据结构:
您还可以使用某种 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)
}