文章詳情頁
node.js - 大用戶量怎么做同時推送
瀏覽:151日期:2022-06-16 10:36:55
問題描述
比如現在有10w用戶,我想請問下如何對這10w人同時進行推送呢
數據庫采用mysql或者mongodb
如果是一臺服務器的話,我的做法是把用戶分批,比如一批1000人,需要100批,同時操作,然后把查詢出來的用戶做推送
如果是多臺服務器的話,需要怎么操作呢?
想一些第三方的推送工具(比如百度推送、小米推送)他們提供推送到全部設備,這里應該就會有上面的問題吧,他們的推送服務器應該不會是一臺,他們是怎么做的處理呢
問題解答
回答1:一臺就慢慢循環(huán)發(fā)多臺就做任務分發(fā)比如10w個用戶需要推送有5臺服務器可以同時工作建立一個中間件(比如mq,redis等)做任務分發(fā),每1000個用戶為一個任務,把10w用戶分成100個任務然后5臺服務器去取任務每次取一個,處理結束在取一個,平均一臺服務器處理20個任務。
分發(fā)的任務可以直接為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. 運行python程序時出現“應用程序發(fā)生異常”的內存錯誤?2. 小白學python的問題 關于%d和%s的區(qū)別3. macos - 無法source activate python274. javascript - npm run build后調用api返回index.html5. github - 求助大神啊,win10 git clone error,折騰了幾天都不行,以前原本好好的,突然就這樣了6. javascript - node得到req不能得到boolean7. css - 關于background-position百分比的問題?8. html - vue里面:src在IE(9-11)下不顯示圖片9. css - angular前端如何讓ng-repeat的內容并排一行,跑起來呢?10. android - 如何實現QQ pad 點擊右側輸入框,只頂右側的布局,左側布局不動
排行榜

網公網安備