您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

从Redis检索大型数据集

从Redis检索大型数据集

首先,它取决于项目的平均大小。

在我的系统上,使用zrangebyscore检索10万个字节的250K项仅需113毫秒。对于100字节的项目,需要228毫秒。对于1 Kb的项目,需要4033毫秒。

因此,除非您的项目比这大得多,否则我会说您的40秒响应时间非常糟糕。

Redis不适用于虚拟内存。如果将Redis内存换出,则性能通常是灾难性的,因此,我要说的第一个操作应该是避免Redis内存换出。

我将尝试转储Redis数据库(使用bgsave,以确保所有页面都返回RAM),然后再次尝试zrangebyscore(和几次)以查看响应时间是否更好。

更新:

这是我用来构建内容的命令:

$ python -c 'for x in range(0,250000): print "ZADD objects:locations 0.1 %0115d" % (x)' | redis-cli | wc

这是我用来计时查询的命令:

$ time redis-cli -h <hostname> zrangebyscore objects:locations -inf +inf >/dev/null
其他 2022/1/1 18:18:02 有652人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶