mysql - PHP定時通知、按時發布怎么做?
問題描述
需求/場景:
比如設置一篇文章2018-5-22 13:51:16發布。
三天后通知我。
消息過期后自動刪除。
……
等等這種需求,就是自動到了一個時間點就做某事,這個跟隊列好像沒什么關系感覺,是不是要什么中間件之類的時間,或是常駐進程之類的。
我的理解是,把待做的任務放到一行一行的一個表里面,然后一個進程不斷的去刷,滿足時間節點的任務就拿出來執行,是這樣的思路嗎。
想知道這種場景成熟的解決方案是用什么做的?
謝謝^_^
問題解答
回答1:用延時任務, https://github.com/ouqiang/go...
延時任務實現方式自己實現, 用時間輪或小根堆
用redis鍵空間通知
beanstalkd
回答2:樓主要的應該是DelayQueue,即延遲消息隊列服務。具體場景可以參考:1.淘寶的自動取消訂單業務2.餓了么下單短信通知業務等等。基于wait/notify的方式把Timer實現。
回答3:就是用程序不斷去刷的= =
回答4:可以使用crontab定時任務來解決,可以來設計每天、小時、分調用Php接口。
回答5:加個時間字段,然后在模型層做相關判斷
回答6:程序刷,但是要考慮數據庫壓力。可以把任務都壓到隊列去,腳本死循環從隊列拿出來,比較時間點,到了就把任務丟給執行模塊。時間點沒到的就繼續另一邊壓入隊列中。
兩個隊列。比如 待執行隊列:tastList; 立即執行隊列:runList。把取任務和執行任務分不同進程:1、取任務:腳本循環從tastList中pop任務,判斷時間點,到點了把這個任務push到runList隊列中去。不到點的繼續壓入到tastList中去;2、執行任務:循環沖runList中去pop,一有任務就馬上執行。
量大的時候,自己根據需要去到開幾個進程就了,也不用考慮說會重復執行。
回答7:用系統的定時任務功能觸發一個腳本就行了。具體腳本干什么,怎么干可以自己隨便啦,參考上面的回答也可以。一般來說一個高頻腳本就夠了(比如1分鐘一次或者5分鐘一次),腳本內再去判斷時間然后調用不同頻率的任務,這樣比每種頻率的腳本分別建立定時任務好管理的多。
回答8:websocket
或者用workerman swoole定時任務功能
回答9:就是你把數據存起來,然后弄個腳本一直去檢測。。比如1分鐘檢測一次
相關文章:
1. python - 獲取到的數據生成新的mysql表2. javascript - js 對中文進行MD5加密和python結果不一樣。3. mysql里的大表用mycat做水平拆分,是不是要先手動分好,再配置mycat4. window下mysql中文亂碼怎么解決??5. sass - gem install compass 使用淘寶 Ruby 安裝失敗,出現 4046. python - (初學者)代碼運行不起來,求指導,謝謝!7. 為啥不用HBuilder?8. python - flask sqlalchemy signals 無法觸發9. python的文件讀寫問題?10. 為什么python中實例檢查推薦使用isinstance而不是type?
