<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • PHP構建監視服務的方法是什么

    時間:2024-09-25 07:03:56 PHP 我要投稿
    • 相關推薦

    PHP構建監視服務的方法是什么

      【提要】本篇《PHP構建監視服務的方法》特別為需要方法編程學習的朋友收集整理的,僅供參考。內容如下:

      PHP監視服務記錄程序應該能夠支持任意的服務檢查(例如,HTTP和FTP服務)并且能夠以任意方式(通過電子郵件,輸出到一個日志文件,等等)記錄事件。你當然想讓它以一個守護程序方式運行;所以,你應該請求它輸出其完整的當前狀態。以下是小編為大家搜索整理的PHP構建監視服務的方法,希望能給大家帶來幫助!

      一個服務需要實現下列抽象類:

      abstract class ServiceCheck {

      const FAILURE = 0;

      const SUCCESS = 1;

      protected $timeout = 30;

      protected $next_attempt;

      protected $current_status = ServiceCheck::SUCCESS;

      protected $previous_status = ServiceCheck::SUCCESS;

      protected $frequency = 30;

      protected $description;

      protected $consecutive_failures = 0;

      protected $status_time;

      protected $failure_time;

      protected $loggers = array();

      abstract public function __construct($params);

      public function __call($name, $args)

      {

      if(isset($this->$name)) {

      return $this->$name;

      }

      }

      public function set_next_attempt()

      {

      $this->next_attempt = time() + $this->frequency;

      }

      public abstract function run();

      public function post_run($status)

      {

      if($status !== $this->current_status) {

      $this->previous_status = $this->current_status;

      }

      if($status === self::FAILURE) {

      if( $this->current_status === self::FAILURE ) {

      $this->consecutive_failures++;

      }

      else {

      $this->failure_time = time();

      }

      }

      else {

      $this->consecutive_failures = 0;

      }

      $this->status_time = time();

      $this->current_status = $status;

      $this->log_service_event();

      }

      public function log_current_status()

      {

      foreach($this->loggers as $logger) {

      $logger->log_current_status($this);

      }

      }

      private function log_service_event()

      {

      foreach($this->loggers as $logger) {

      $logger->log_service_event($this);

      }

      }

      public function register_logger(ServiceLogger $logger)

      {

      $this->loggers[] = $logger;

      }

      }

      上面的__call()重載方法提供對一個ServiceCheck對象的參數的只讀存取操作:

      · timeout-在引擎終止檢查之前,這一檢查能夠掛起多長時間。

      · next_attempt-下次嘗試連接到服務器的時間。

      · current_status-服務的當前狀態:SUCCESS或FAILURE。

      · previous_status-當前狀態之前的狀態。

      · frequency-每隔多長時間檢查一次服務。

      · description-服務描述。

      · consecutive_failures-自從上次成功以來,服務檢查連續失

      敗的次數。

      · status_time-服務被檢查的最后時間。

      · failure_time-如果狀態為FAILED,則它代表發生失敗的時間。

      這個類還實現了觀察者模式,允許ServiceLogger類型的對象注冊自身,然后當調用log_current_status()或log_service_event()時調用它。

      這里實現的關鍵函數是run(),它負責定義應該怎樣執行檢查。如果檢查成功,它應該返回SUCCESS;否則返回FAILURE。

    【PHP構建監視服務的方法是什么】相關文章:

    如何使用PHP構建一個高性能的彈幕后端服務01-22

    PHP錯誤類型及屏蔽方法08-22

    PHP處理密碼的幾種方法10-17

    十天學會php的方法09-23

    MongoDB的PHP驅動方法與技巧大全09-08

    了解PHP環境搭建與配置的方法08-03

    PHP開發環境安裝的方法有哪些10-27

    php在新浪云中使用imagick的方法07-14

    構建生產結構優化系統的方法07-31

    構建企業內訓體系的方法12-30

    主站蜘蛛池模板: 国产伦精品一区二区三区| 亚洲性日韩精品一区二区三区| 久久99亚洲综合精品首页| 欧美精品国产精品| 国产精品久久久久久影院| 国产精品免费看久久久| 精品无码国产污污污免费网站国产 | 中文字幕在线亚洲精品| 亚洲AV永久无码精品一区二区| 午夜精品久久久久久| 亚洲视频在线精品| 国产精品福利在线观看免费不卡| 9re热国产这里只有精品| 精品熟女少妇aⅴ免费久久| 免费91麻豆精品国产自产在线观看| 无码精品国产VA在线观看DVD | 欧美精品久久久久久久自慰| 久久99精品久久久久久hb无码| 99re6在线视频精品免费| 成人精品视频成人影院| 8x福利精品第一导航| www亚洲欲色成人久久精品| 国产精品免费无遮挡无码永久视频| 亚洲精品狼友在线播放| 国产福利91精品一区二区| 色国产精品一区在线观看| 亚洲精品欧美二区三区中文字幕| 精品人妻一区二区三区毛片| 国产精品最新国产精品第十页 | 国产精品色视频ⅹxxx | 999精品在线| 国产2021精品视频免费播放 | 欧洲精品码一区二区三区免费看 | 精品一区二区三区四区| 久久国产午夜精品一区二区三区| 丰满人妻熟妇乱又伦精品劲| 欧美精品在线一区二区三区| 久久青青草原精品影院| 精品视频第一页| 久久亚洲国产精品一区二区 | 亚洲国产精品乱码一区二区|