mysql - PHP定時(shí)通知、按時(shí)發(fā)布怎么做?
問題描述
需求/場(chǎng)景:
比如設(shè)置一篇文章2018-5-22 13:51:16發(fā)布。
三天后通知我。
消息過期后自動(dòng)刪除。
……
等等這種需求,就是自動(dòng)到了一個(gè)時(shí)間點(diǎn)就做某事,這個(gè)跟隊(duì)列好像沒什么關(guān)系感覺,是不是要什么中間件之類的時(shí)間,或是常駐進(jìn)程之類的。
我的理解是,把待做的任務(wù)放到一行一行的一個(gè)表里面,然后一個(gè)進(jìn)程不斷的去刷,滿足時(shí)間節(jié)點(diǎn)的任務(wù)就拿出來執(zhí)行,是這樣的思路嗎。
想知道這種場(chǎng)景成熟的解決方案是用什么做的?
謝謝^_^
問題解答
回答1:用延時(shí)任務(wù), https://github.com/ouqiang/go...
延時(shí)任務(wù)實(shí)現(xiàn)方式自己實(shí)現(xiàn), 用時(shí)間輪或小根堆
用redis鍵空間通知
beanstalkd
回答2:樓主要的應(yīng)該是DelayQueue,即延遲消息隊(duì)列服務(wù)。具體場(chǎng)景可以參考:1.淘寶的自動(dòng)取消訂單業(yè)務(wù)2.餓了么下單短信通知業(yè)務(wù)等等。基于wait/notify的方式把Timer實(shí)現(xiàn)。
回答3:就是用程序不斷去刷的= =
回答4:可以使用crontab定時(shí)任務(wù)來解決,可以來設(shè)計(jì)每天、小時(shí)、分調(diào)用Php接口。
回答5:加個(gè)時(shí)間字段,然后在模型層做相關(guān)判斷
回答6:程序刷,但是要考慮數(shù)據(jù)庫壓力。可以把任務(wù)都?jí)旱疥?duì)列去,腳本死循環(huán)從隊(duì)列拿出來,比較時(shí)間點(diǎn),到了就把任務(wù)丟給執(zhí)行模塊。時(shí)間點(diǎn)沒到的就繼續(xù)另一邊壓入隊(duì)列中。
兩個(gè)隊(duì)列。比如 待執(zhí)行隊(duì)列:tastList; 立即執(zhí)行隊(duì)列:runList。把取任務(wù)和執(zhí)行任務(wù)分不同進(jìn)程:1、取任務(wù):腳本循環(huán)從tastList中pop任務(wù),判斷時(shí)間點(diǎn),到點(diǎn)了把這個(gè)任務(wù)push到runList隊(duì)列中去。不到點(diǎn)的繼續(xù)壓入到tastList中去;2、執(zhí)行任務(wù):循環(huán)沖runList中去pop,一有任務(wù)就馬上執(zhí)行。
量大的時(shí)候,自己根據(jù)需要去到開幾個(gè)進(jìn)程就了,也不用考慮說會(huì)重復(fù)執(zhí)行。
回答7:用系統(tǒng)的定時(shí)任務(wù)功能觸發(fā)一個(gè)腳本就行了。具體腳本干什么,怎么干可以自己隨便啦,參考上面的回答也可以。一般來說一個(gè)高頻腳本就夠了(比如1分鐘一次或者5分鐘一次),腳本內(nèi)再去判斷時(shí)間然后調(diào)用不同頻率的任務(wù),這樣比每種頻率的腳本分別建立定時(shí)任務(wù)好管理的多。
回答8:websocket
或者用workerman swoole定時(shí)任務(wù)功能
回答9:就是你把數(shù)據(jù)存起來,然后弄個(gè)腳本一直去檢測(cè)。。比如1分鐘檢測(cè)一次
相關(guān)文章:
1. mysql - 分庫分表、分區(qū)、讀寫分離 這些都是用在什么場(chǎng)景下 ,會(huì)帶來哪些效率或者其他方面的好處2. javascript - vue-echarts-v3使用的過程中折線圖區(qū)域呈漸變色。3. 關(guān)于Mysql聯(lián)合查詢4. centos7 編譯安裝 Python 3.5.1 失敗5. mysql - 這個(gè)數(shù)據(jù)庫合計(jì)用 視圖做,和直接算好存在數(shù)據(jù)庫里,到時(shí)候調(diào)用起來哪個(gè)快?6. 人工智能 - python 機(jī)器學(xué)習(xí) 醫(yī)療數(shù)據(jù) 怎么學(xué)7. python - beautifulsoup獲取網(wǎng)頁內(nèi)容的問題8. python - 在django內(nèi)如何讓后臺(tái)增加的文章自動(dòng)加上是哪個(gè)用戶編輯的呢?9. pip安裝提示Twisted錯(cuò)誤問題(Python3.6.4安裝Twisted錯(cuò)誤)10. c++ - 請(qǐng)問MySQL_Connection::isReadOnly 怎么解決?
