免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2163 | 回复: 1
打印 上一主题 下一主题

[算法] 一道笔试题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-04-14 12:15 |只看该作者 |倒序浏览
本帖最后由 你还未够水准呢 于 2013-04-14 13:39 编辑

qq 用户有 30 亿,每日的登陆、登出的日志条目有 100 亿之多,

设计程序统计每天登陆人数;

设计程序剔除因为掉线而重复登陆的情况;

设计程序求出在线人数最高的时刻。

日志条目 格式 可以看作

QQ号码 用户ID 登入时间 登出时间
XXXXX   XXXXX   XXXXX    XXXXX

传送门 转移 http://v2ex.com/t/65589#reply21

这个帖子有不少思路

各位有啥见解~~~

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
2 [报告]
发表于 2013-04-14 16:14 |只看该作者
1, 这种级别的项目都是有实时曲线监控的,聊天服务器内部维护在线用户数,监控平台按周期去拉统计数据展现成曲线,可以达到分钟级实时性。

2, 做独立的log server来做日实时统计,腾讯的QQ号是整形,并且以整形号段分组的,可以建立每个组的对应的log server,做内存级别的去重统计(一个哈希表的事情)以及最高在线用户数记录(一个max变量的事情).

其他: 为了避免log server在组内单点,需要做至少一个热备,或者参考redis或者参考mysql。
redis: slave启动后同步master内存镜像,完成后将同步期间以及之后的操作异步传送slave。
mysql: master操作内存前写磁盘log,slave则请求master同步磁盘log。

但如果是master和slave之间网络坏了,那就比较蛋疼了。

至于故障转移,不仅要转移,还要保证可以进行写操作,就更难做了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP