文章详情页
node.js - 大用户量怎么做同时推送
浏览:153日期:2022-06-16 10:36:55
问题描述
比如现在有10w用户,我想请问下如何对这10w人同时进行推送呢
数据库采用mysql或者mongodb
如果是一台服务器的话,我的做法是把用户分批,比如一批1000人,需要100批,同时操作,然后把查询出来的用户做推送
如果是多台服务器的话,需要怎么操作呢?
想一些第三方的推送工具(比如百度推送、小米推送)他们提供推送到全部设备,这里应该就会有上面的问题吧,他们的推送服务器应该不会是一台,他们是怎么做的处理呢
问题解答
回答1:一台就慢慢循环发多台就做任务分发比如10w个用户需要推送有5台服务器可以同时工作建立一个中间件(比如mq,redis等)做任务分发,每1000个用户为一个任务,把10w用户分成100个任务然后5台服务器去取任务每次取一个,处理结束在取一个,平均一台服务器处理20个任务。
分发的任务可以直接为mysql或者mongodb的查询语句例如 mongodb.user.find().limit(1000).skip(0),mongodb.user.find().limit(1000).skip(1000),mongodb.user.find().limit(1000).skip(2000)...
回答2:查询比率的数据推...
回答3:我们是用的极光推送的服务
上一条:MySQL 书籍推荐下一条:一个MySQL关联查询是否存在的问题
相关文章:
1. javascript - 给某个类添加一个伪类,这个类有click事件,现在我点击伪类也触发了click事件2. angular.js - angular内容过长展开收起效果3. docker绑定了nginx端口 外部访问不到4. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?5. docker gitlab 如何git clone?6. 小白学python的问题 关于%d和%s的区别7. angular.js - 怎样实现点击 “分数” 后按分数升序和降序排列?8. css - 如何更改 iOS 和安卓浏览器上的 input[type="radio"] 元素的默认样式?9. javascript - 这是什么数组?10. javascript - 怎样去除数组里的几个值,只提供该数组的下标的话
排行榜

网公网安备