如何在 1s 内统计出 13 亿人口数据找出使用人数最多的十个姓名

2021-01-25 10:32:21 +08:00
 cage111

请教下各位大佬这种需求可以实现吗

13729 次点击
所在节点    数据库
104 条回复
mybyons
2021-01-26 07:09:50 +08:00
Top-K 的问题求解 Probabilistic 问题

可以参考一下 Redis 的 Top-K Module 根据官方的测试数据 500,000 words.的世界文学 世界与和平 用时大概 1 Sec 就算出来了 这个时间包括了文件读取 和 词拆分 的时间. 如果减去这个时间 再能够优化一下 redis pipeline 还能优化一些

当然这个还差两到三个数量级的差距 那就 shard 100 个实例 最后再 merge

周末可以在云端试一下....haha....

参考 1. https://redislabs.com/blog/meet-top-k-awesome-probabilistic-addition-redisbloom/#:~:text=Redis'%20Sorted%20Set%20data%20structure,is%20initialized%20with%20the%20TOPK.
cveoy
2021-01-26 09:53:50 +08:00
只要机器够 100ms 也可以 给我来 5000 台 redis 或者 es mysql 都可以
xieshaohu
2021-01-26 16:47:54 +08:00
@cage111 查询条件和 groupby 条件都做成 orderby key
troywinter
2021-01-26 23:43:31 +08:00
我来安利一波 apache pinot,性能强过 druid,这种统计可以 200ms 内返回。

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

https://tanronggui.xyz/t/748059

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

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

© 2021 V2EX