婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > laravel異步監控定時調度器實例詳解

laravel異步監控定時調度器實例詳解

熱門標簽:咸寧銷售電銷機器人系統 百度地圖怎樣標注圖標 電銷機器人問門薩維品牌my 百度地圖標注偏差 開發地圖標注類網站 余姚電話機器人 外呼系統能給企業帶來哪些好處 廣東廣州在怎么申請400電話 400電話蘭州申請請

定時調度器是什么

laravel默認提供了一個命令定時任務的功能,在其他的php框架下面,沒有這個定時任務,我們要跑一些異步腳本怎么操作呢,只能依賴我們系統提供的crontab來做,這就導致我們每次發版本新增定時任務都要去服務器更改crontab代碼,獲取更新這個配置。

執行命令是php artisan schedule:run 來執行,那放在哪里執行呢,沒錯這個調起還是需要依賴我們crontab來執行,但是只需要配置一次,后續所有定時任務都在我們業務代碼進行控制

場景

我們有一個導入數據的定時任務

//每分鐘導入庫數據
$schedule->command(self::SIGNATURE)->withoutOverlapping()->everyMinute()->runInBackground();

這里導入長時間最好使用runInBackground(),表示異步執行,其實就是在shell腳本的末尾加上 符號,在linux上完全依賴系統的方式完成。

這里使用了withoutOverlapping() 表示在同一時刻只能有一個任務執行,主要邏輯使用的是排它鎖實現,依賴于我們cache的driver,我這里使用的是redis,后面作為鎖的過期直接redis提供的key過期來做。

出現問題

這個任務在正常情況下都是非常完美的,因為同一時刻只有一個再跑,跑完就可以,但是一個場景出現
有一天我們的qa同學剛部署環境后,我們服務端就在默默的導入庫了,因為使用withoutOverlapping($expire_at=1440)這個時候在redis就有一個鎖產生了,這個默認帶參數是鎖的過期時間,默認是一天,然后因為我們docker環境需要更改參數然后進行后端server服務的重啟,我們重啟也是比較暴力,就是直接發送kill的信號,導致所有在里面跑的進程瞬間kill,而這時候我們的redis的鎖缺還存在,而且是1440分鐘左右,那當我們server再啟動后,發現鎖一直存在,沒辦法進行后續的操作了,只能等著。

解決

那我把鎖的時間減少行不行,原來1天,我改成30分鐘,沒問題,開始第一版方案我們也是這樣做,官方也是可以這樣做的。

后來我們一想,能否做到一個監控程序呢,進程退出后立馬監控到過期呢,這樣就不用固定一個時間,這當然是所有軟件開發者理想狀態:要你開你就開,我掛了鎖也就去掉了,不論正常與否。

解決方案

說明:

  • 這里命令啟動時候,獲取進程的pid,然后fork子進程,可以將這個pid傳遞給子進程。
  • 子進程每隔10s進行一個探活,獲取父進程的id與傳入的pid是否一致,這里普及一個知識點,如果父進程異常退出,這個子進程未退出就會被init進程(pid=1)接管,那么這就是一個孤兒進程。
  • 同時子進程每次探活的時候就會更改redis的鎖的過期時間,如果探活時間間隔是10s,那么我們的過期時間設置就是14s,多冗余一點時間。

代碼實現

代碼實現總是那么蒼白無力哈,這里就寫一個laravel的擴展來做,好處就是不影響我們主體的任何代碼就完成了,我們的laravel可以隨意升級。

github地址:github.com/zzh78727258…

composer地址:packagist.org/packages/ze…

總結

整體實現沒有使用判斷進程是否存在的ps grep等命令,因為我們docker環境不一定支持這些命令,只是用簡單的pid與parent_id做對比。

laravel的在命令開始于結束都進行鉤子方式,我們在Listener下面進行監聽即可

public function subscribe($events)
 {
  $events->listen(
   [
    CommandStarting::class, // 命令開始的時候
   ],
   __CLASS__ . '@handle'
  );
 }

整體代碼是基于laravel擴展化的,不會影響laravel的升級操作。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Laravel中任務調度console使用方法小結

標簽:巴彥淖爾 十堰 臨沂 銅陵 鷹潭 麗江 重慶 衡陽

巨人網絡通訊聲明:本文標題《laravel異步監控定時調度器實例詳解》,本文關鍵詞  laravel,異步,監控,定時,調度,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《laravel異步監控定時調度器實例詳解》相關的同類信息!
  • 本頁收集關于laravel異步監控定時調度器實例詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 海安县| 华阴市| 宜良县| 井冈山市| 临桂县| 五常市| 山阳县| 罗城| 沾益县| 翁牛特旗| 临江市| 贵阳市| 江永县| 永嘉县| 安福县| 苗栗市| 江城| 安陆市| 横山县| 内江市| 宾阳县| 襄汾县| 油尖旺区| 西华县| 保亭| 驻马店市| 吉木乃县| 贞丰县| 金乡县| 双城市| 阳谷县| 右玉县| 枣阳市| 清涧县| 苗栗县| 名山县| 德化县| 青田县| 金平| 聂拉木县| 宜兰县|