摘要:再確認(rèn)使用方法的時(shí)候,由于使用的這種開(kāi)發(fā)語(yǔ)言,所以想實(shí)現(xiàn)定時(shí)器功能需要借助或者。
真沒(méi)想到自己的這篇很水的文章還有一些可愛(ài)的朋友們?nèi)ラ喿x,真的很感謝你們。其實(shí)這篇文章是我在元旦假期最后一天無(wú)事可做的時(shí)候偶然腦子抽搐想到的一個(gè)場(chǎng)景,然后試著去實(shí)現(xiàn)的,其實(shí)訂單自動(dòng)取消功能網(wǎng)上有很多可借鑒的方法,包括評(píng)論區(qū)的朋友們提到的定時(shí)任務(wù)和消息隊(duì)列,我這個(gè)只是在一個(gè)自己想到的方法(我承認(rèn)真的真的很水)。
感謝評(píng)論區(qū)的朋友們的熱心建議和教導(dǎo),我也會(huì)去借鑒一下你們的指導(dǎo)意見(jiàn),同時(shí)繼續(xù)學(xué)習(xí),再次對(duì)你們表示感謝~?( ′???` )比心
以下是原文:
業(yè)務(wù)需求最近在做業(yè)務(wù)的時(shí)候需要實(shí)現(xiàn)客戶下單之后訂單超時(shí)未支付自動(dòng)取消的功能,剛開(kāi)始確認(rèn)了幾種方法:
客戶端到時(shí)間請(qǐng)求取消
服務(wù)端定時(shí)查詢有沒(méi)有需要取消的訂單,然后批量處理
下單后創(chuàng)建定時(shí)器,延時(shí)處理
使用redis或者memcache存儲(chǔ),設(shè)置過(guò)期時(shí)間,自動(dòng)刪除
綜合考慮上述方法,第一種最先排除,因?yàn)槿绻蛻舭袮PP后臺(tái)禁止或者網(wǎng)絡(luò)連接禁止,那么就無(wú)法發(fā)給服務(wù)端請(qǐng)求,訂單就會(huì)一直是未處理狀態(tài);第二種方法使用的比較多,不過(guò)存在準(zhǔn)確度的問(wèn)題,還有需要確認(rèn)定時(shí)任務(wù)的周期,暫時(shí)列為后補(bǔ)方法;第四種方法存在的問(wèn)題就是訂單如果刪除就是物理刪除,無(wú)法統(tǒng)計(jì)未處理數(shù)據(jù)(當(dāng)然可以存redis時(shí)候順便存在mysql這樣的數(shù)據(jù)庫(kù)做長(zhǎng)久存儲(chǔ)然后用方法二定時(shí)處理)。
最終準(zhǔn)備使用方法三。
再確認(rèn)使用方法3的時(shí)候,由于使用的PHP這種開(kāi)發(fā)語(yǔ)言,所以想實(shí)現(xiàn)定時(shí)器功能需要借助Swoole或者workerman。由于Swoole是C開(kāi)發(fā)的擴(kuò)展框架,性能方面肯定比較好,就選了Swoole。
使用Swoole首先需要在服務(wù)器上安裝Swoole擴(kuò)展,安裝方法和安裝其他擴(kuò)展大同小異,可以參考這邊文章
安裝完之后檢測(cè)下擴(kuò)展是否正常安裝,查看phpinfo或者PHP-m,如果出現(xiàn)Swoole,則說(shuō)明安裝成功
Swoole官方文檔有定時(shí)器的相關(guān)文檔
開(kāi)始測(cè)試我們創(chuàng)建一個(gè)swoole_test.php文件和一個(gè)log.txt文件(用來(lái)測(cè)試),swoole_test.php代碼如下:
然后在網(wǎng)頁(yè)訪問(wèn)這個(gè)PHP文件,結(jié)果如下:
然后在Linux終端運(yùn)行PHP:/usr/local/php7/bin/php /home/app/swoole_test.php,結(jié)果如下:
內(nèi)心一陣。。。
原來(lái)定時(shí)器只能在cli模式下,那么這個(gè)想法怕是要GG了,難道就栽倒這里了嗎,難道就沒(méi)有別的方法了嗎?就在我欲哭無(wú)淚的時(shí)候突然靈光乍現(xiàn),一個(gè)詞閃到我的腦海:Python!
對(duì),我們不能單單靠著PHP啊,還有Python這種神奇的語(yǔ)言呢,我們知道Python的os模塊里的os.system方法是可以執(zhí)行命令行的,那么不就可以實(shí)現(xiàn)在cli模式下運(yùn)行剛才的swoole_test.php文件了么。
內(nèi)心一陣激動(dòng)后,覺(jué)得測(cè)試是否可行
我們知道Linux都是自帶Python的,但是不同的版本Python版本不同,有的自帶的是Python2.6,版本過(guò)低了,所以需要裝一個(gè)高版本的,這里我選擇Python3,注意不要覆蓋系統(tǒng)自帶的Python2 。以下是大致的安裝步驟:wget http://python.org/ftp/python/...
tar xf Python-3.6.0.tar.xz
cd Python-3.6.0
./configure --prefix=/usr/local/python3
make && make install
ln -s /usr/local/python3/bin/python3 /usr/bin/python3
接下來(lái)終端輸入:Python3,如果出現(xiàn)
則安裝成功。
安裝完Python3之后,我們新建一個(gè)test.py文件,內(nèi)容如下:#!usr/bin/env python3` #-*- coding:utf-8 -*- import os ret = os.system("/usr/local/php7/bin/php /home/app/swoole_test.php") #請(qǐng)使用自己系統(tǒng)的絕對(duì)路徑 print(ret)然后我們?cè)诮K端執(zhí)行:/usr/bin/python3 /home/app/test.py,注意:這里只是執(zhí)行PHP文件,但是文件里的echo內(nèi)容是不會(huì)在終端輸出的,這時(shí)候就用到剛才新建的log.txt文件了。執(zhí)行完Python文件后,我們?nèi)og文件檢查下,發(fā)現(xiàn)內(nèi)容已經(jīng)寫(xiě)入,所以使用Python是可以實(shí)現(xiàn)PHP的cli模式的。┗|`O′|┛ 嗷~~
到這里就會(huì)有同學(xué)疑惑了,你這使用Python實(shí)現(xiàn)了PHP的cli模式,但是怎么通過(guò)web遠(yuǎn)程訪問(wèn)呢?這個(gè)時(shí)候就用到PHP的exec方法了,我們知道PHP的exec方法和Python的os.system方法一樣是可以執(zhí)行命令行命令的,所以我們可以新建一個(gè)test.php文件,內(nèi)容如下:
"; (exec ($program)); echo "end
"; die;然后我們通過(guò)網(wǎng)頁(yè)訪問(wèn)test.php文件。結(jié)果如下:
然后去log文件檢查,發(fā)現(xiàn)也寫(xiě)入日志了,所以這個(gè)方法是可行的!
做到這里心里美滋滋的,不過(guò)老覺(jué)得好像哪里不對(duì),終于終于意識(shí)到一個(gè)很傻逼的問(wèn)題:既然PHP可以直接有命令行函數(shù),為啥多此一舉借助Python然后在用Python的函數(shù)呢?這不是脫了褲子放屁多此一舉嗎?
再大罵自己是傻逼N遍之后,我默默修改了test.php文件內(nèi)容:"; $program="/usr/local/php7/bin/php /home/app/nongyephp/swoole_test.php"; #注意使用絕對(duì)路徑 (exec ($program)); echo "end
"; die;在直接訪問(wèn)test.php文件,反饋結(jié)果和借助Python一樣,這樣就可以免去Python那一步,直接用PHP的exec函數(shù)來(lái)執(zhí)行PHP文件。
結(jié)尾測(cè)試通過(guò)后發(fā)現(xiàn)這種方法是可以創(chuàng)建定時(shí)器并且通過(guò)web遠(yuǎn)程使用的,不過(guò)有個(gè)問(wèn)題,如果用和我上述一樣用網(wǎng)頁(yè)模擬會(huì)發(fā)現(xiàn)網(wǎng)頁(yè)刷新是要等test.php執(zhí)行完才會(huì)結(jié)束,也就是說(shuō)如果我們把延時(shí)器的時(shí)間設(shè)成30分鐘會(huì)要等待30分鐘才會(huì)有反饋信息,這種方式肯定行不通的,所以需要使用異步訪問(wèn),比如使用web的ajax技術(shù)和其他異步技術(shù),這里不再贅述
尾巴以上只是我想到解決問(wèn)題的想法和實(shí)施步驟,到了真正開(kāi)發(fā)可能不會(huì)選擇這種方式,因?yàn)闆](méi)有經(jīng)過(guò)性能測(cè)試,而且對(duì)于進(jìn)程控制和線程控制并沒(méi)有多深入的了解,所以以后做訂單自動(dòng)取消還是會(huì)選擇方法2的吧。
上述方法其實(shí)完全可以省掉Python那一步,我沒(méi)有去掉的原因是把我的實(shí)現(xiàn)經(jīng)歷寫(xiě)出來(lái),因?yàn)槲矣X(jué)得開(kāi)發(fā)期間可能真的會(huì)遇到這種多此一舉的方式,總之是要多思考,多看代碼,找出能優(yōu)化的方案,這里感覺(jué)自己差得很遠(yuǎn),共勉吧
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/41128.html
摘要:再確認(rèn)使用方法的時(shí)候,由于使用的這種開(kāi)發(fā)語(yǔ)言,所以想實(shí)現(xiàn)定時(shí)器功能需要借助或者。 真沒(méi)想到自己的這篇很水的文章還有一些可愛(ài)的朋友們?nèi)ラ喿x,真的很感謝你們。其實(shí)這篇文章是我在元旦假期最后一天無(wú)事可做的時(shí)候偶然腦子抽搐想到的一個(gè)場(chǎng)景,然后試著去實(shí)現(xiàn)的,其實(shí)訂單自動(dòng)取消功能網(wǎng)上有很多可借鑒的方法,包括評(píng)論區(qū)的朋友們提到的定時(shí)任務(wù)和消息隊(duì)列,我這個(gè)只是在一個(gè)自己想到的方法(我承認(rèn)真的真的很水)...
摘要:支持消息刪除業(yè)務(wù)使用方,可以隨時(shí)刪除指定消息。消息傳輸可靠性消息進(jìn)入到延遲隊(duì)列后,保證至少被消費(fèi)一次。 延遲隊(duì)列,顧名思義它是一種帶有延遲功能的消息隊(duì)列。 那么,是在什么場(chǎng)景下我才需要這樣的隊(duì)列呢? 一、背景 先看看一下業(yè)務(wù)場(chǎng)景: 1.會(huì)員過(guò)期前3天發(fā)送召回通知 2.訂單支付成功后,5分鐘后檢測(cè)下游環(huán)節(jié)是否都正常,比如用戶購(gòu)買會(huì)員后,各種會(huì)員狀態(tài)是否都設(shè)置成功 3.如何定期檢查處于退...
摘要:一在各種電商網(wǎng)站下訂單后會(huì)保留一個(gè)時(shí)間段,時(shí)間段內(nèi)未支付則自動(dòng)將訂單狀態(tài)設(shè)置為已過(guò)期。并修改這些數(shù)據(jù)的狀態(tài)為已過(guò)期。因此以上方式實(shí)際開(kāi)發(fā)中基本不予采用。時(shí)間到期了才會(huì)發(fā)送這條消息到消息隊(duì)列中。 一、在各種電商網(wǎng)站下訂單后會(huì)保留一個(gè)時(shí)間段,時(shí)間段內(nèi)未支付則自動(dòng)將訂單狀態(tài)設(shè)置為已過(guò)期。(原文鏈接 ) showImg(https://segmentfault.com/img/bVbv9BX?...
摘要:高性能高精度定時(shí)服務(wù),輕松管理千萬(wàn)級(jí)定時(shí)任務(wù)。支持任務(wù)到期觸發(fā)和。支持創(chuàng)建延時(shí)任務(wù)和定時(shí)到期任務(wù),和原生保持相同接口,輕松使用。不支持任務(wù)輸出任務(wù)鉤子及維護(hù)模式。是不指定任務(wù)名時(shí)自動(dòng)生成,每個(gè)任務(wù)名必須唯一,相同任務(wù)名重復(fù)定義將會(huì)自動(dòng)覆蓋。 Forsun高性能高精度定時(shí)服務(wù),輕松管理千萬(wàn)級(jí)定時(shí)任務(wù)。 定時(shí)服務(wù)項(xiàng)目地址:https://github.com/snower/forsun l...
閱讀 1244·2023-04-25 15:53
閱讀 2112·2021-11-19 09:40
閱讀 3505·2021-10-11 10:59
閱讀 2084·2019-08-30 15:55
閱讀 1968·2019-08-30 15:54
閱讀 2318·2019-08-29 13:03
閱讀 2771·2019-08-28 18:17
閱讀 1520·2019-08-27 10:51