mysql - PHP定時通知、按時發(fā)布怎么做?
問題描述
需求/場景:
比如設(shè)置一篇文章2018-5-22 13:51:16發(fā)布。
三天后通知我。
消息過期后自動刪除。
……
等等這種需求,就是自動到了一個時間點(diǎn)就做某事,這個跟隊(duì)列好像沒什么關(guān)系感覺,是不是要什么中間件之類的時間,或是常駐進(jìn)程之類的。
我的理解是,把待做的任務(wù)放到一行一行的一個表里面,然后一個進(jìn)程不斷的去刷,滿足時間節(jié)點(diǎn)的任務(wù)就拿出來執(zhí)行,是這樣的思路嗎。
想知道這種場景成熟的解決方案是用什么做的?
謝謝^_^
問題解答
回答1:用延時任務(wù), https://github.com/ouqiang/go...
延時任務(wù)實(shí)現(xiàn)方式自己實(shí)現(xiàn), 用時間輪或小根堆
用redis鍵空間通知
beanstalkd
回答2:樓主要的應(yīng)該是DelayQueue,即延遲消息隊(duì)列服務(wù)。具體場景可以參考:1.淘寶的自動取消訂單業(yè)務(wù)2.餓了么下單短信通知業(yè)務(wù)等等。基于wait/notify的方式把Timer實(shí)現(xiàn)。
回答3:就是用程序不斷去刷的= =
回答4:可以使用crontab定時任務(wù)來解決,可以來設(shè)計每天、小時、分調(diào)用Php接口。
回答5:加個時間字段,然后在模型層做相關(guān)判斷
回答6:程序刷,但是要考慮數(shù)據(jù)庫壓力。可以把任務(wù)都壓到隊(duì)列去,腳本死循環(huán)從隊(duì)列拿出來,比較時間點(diǎn),到了就把任務(wù)丟給執(zhí)行模塊。時間點(diǎn)沒到的就繼續(xù)另一邊壓入隊(duì)列中。
兩個隊(duì)列。比如 待執(zhí)行隊(duì)列:tastList; 立即執(zhí)行隊(duì)列:runList。把取任務(wù)和執(zhí)行任務(wù)分不同進(jìn)程:1、取任務(wù):腳本循環(huán)從tastList中pop任務(wù),判斷時間點(diǎn),到點(diǎn)了把這個任務(wù)push到runList隊(duì)列中去。不到點(diǎn)的繼續(xù)壓入到tastList中去;2、執(zhí)行任務(wù):循環(huán)沖runList中去pop,一有任務(wù)就馬上執(zhí)行。
量大的時候,自己根據(jù)需要去到開幾個進(jìn)程就了,也不用考慮說會重復(fù)執(zhí)行。
回答7:用系統(tǒng)的定時任務(wù)功能觸發(fā)一個腳本就行了。具體腳本干什么,怎么干可以自己隨便啦,參考上面的回答也可以。一般來說一個高頻腳本就夠了(比如1分鐘一次或者5分鐘一次),腳本內(nèi)再去判斷時間然后調(diào)用不同頻率的任務(wù),這樣比每種頻率的腳本分別建立定時任務(wù)好管理的多。
回答8:websocket
或者用workerman swoole定時任務(wù)功能
回答9:就是你把數(shù)據(jù)存起來,然后弄個腳本一直去檢測。。比如1分鐘檢測一次
相關(guān)文章:
