第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請教一個后端/后臺的設(shè)計思路.感激不盡

請教一個后端/后臺的設(shè)計思路.感激不盡

開滿天機(jī) 2019-10-08 11:20:34
①問題場景:一個新用戶注冊后,會有一個任務(wù)開始執(zhí)行,每個用戶都有自己對應(yīng)單獨(dú)的一個任務(wù).這個任務(wù)是24*7一直在實(shí)時運(yùn)行監(jiān)控的(計算任務(wù)/Http請求/耗時任務(wù)).(有點(diǎn)類似攜程app高鐵票搶票的意思.)②我的思路:一開始想的是一個新用戶進(jìn)來就新開一條線程.或者管理一個線程池,把任務(wù)全都放進(jìn)一個隊(duì)列中.循環(huán)的在線程池進(jìn)行任務(wù)的計算.但是中途會有新用戶(任務(wù))進(jìn)來.而且這樣如果用戶量一多的話好像想過不是很理性.也就是線程池每批進(jìn)行n個任務(wù)的運(yùn)行.但是這樣所有用戶一輪下來時間好像有點(diǎn)長.③向大佬請教:我也挺小白的,所以想問一下具體這種場景比較推薦怎么樣的實(shí)現(xiàn)方式/思路.困擾了我好久.**感謝大佬.!**
查看完整描述

2 回答

?
人到中年有點(diǎn)甜

TA貢獻(xiàn)1895條經(jīng)驗(yàn) 獲得超7個贊

建立任務(wù)池,多個任務(wù)節(jié)點(diǎn)監(jiān)控任務(wù)池,一旦有任務(wù)進(jìn)入任務(wù)池就自動領(lǐng)任務(wù)定時任務(wù)創(chuàng)建程序定時將任務(wù)扔入任務(wù)池用戶注冊成功之后加入定時任務(wù)里
任務(wù)創(chuàng)建-->任務(wù)池-->任務(wù)節(jié)點(diǎn)運(yùn)行任務(wù)
                            
查看完整回答
反對 回復(fù) 2019-10-08
?
茅侃侃

TA貢獻(xiàn)1842條經(jīng)驗(yàn) 獲得超21個贊

單機(jī)的就不說了。數(shù)據(jù)量大了,肯定要用分布式。下面說下分布式的思想(假設(shè)有n個任務(wù)節(jié)點(diǎn)):
可以通過一致性hash的方式去分配任務(wù),用zookeeper做任務(wù)注冊,管理中心。有新用戶注冊,就向數(shù)據(jù)庫寫一條任務(wù)數(shù)據(jù),并向zookeeper注冊任務(wù)id。節(jié)點(diǎn)通過zookeeper去獲取任務(wù)id,然后去數(shù)據(jù)庫查詢相應(yīng)任務(wù)數(shù)據(jù),并運(yùn)行。
或者簡單點(diǎn),任務(wù)節(jié)點(diǎn)直接去數(shù)據(jù)庫取模jobId%n獲取任務(wù),jobId為任務(wù)的自增id。只不過這樣的話,相比一致性hash,當(dāng)增加/減少節(jié)點(diǎn)時,任務(wù)的重新分配會比較麻煩。
                            
查看完整回答
反對 回復(fù) 2019-10-08
  • 2 回答
  • 0 關(guān)注
  • 248 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號