首頁  >  文章  >  後端開發  >  php寫後端運行程式總結

php寫後端運行程式總結

巴扎黑
巴扎黑原創
2016-11-23 14:42:411856瀏覽

1、定時執行

         就crontab了,linux命令,具體怎麼用,自己google。只想說一點,crontab的時候要注意權限,維運常會用root來啟動,導致有些檔案web使用者無權限。

2、後台守護

        分兩步驟:1需要在腳本中寫死循環,因為php不像python,我通常是do {....} while (true); 不過sleep的,不然機器會被跑死;2啟動進程的時候需要在後面加個「&」 ,這個大家也google吧,如果需要記錄輸出的資訊需要這樣寫php xxxx.php > /tmp/phplog &,這樣程式的資訊就記錄到文件裡了,方便以後排除問題。

3、運行監控

       後台守護的進程啟動了,但是你無法100%肯定你的程序不會出現警告信息,一旦出現這些信息,php會終止掉當前的進程,這個時候後台的程序就直接退出了。所以除了正常處理事情的程序外,還需要一個檢查那個程序運行狀態的程序,我通常會叫xxxxDefend.php,這個程序示例如下

 #!/usr/local/php5/bin/php

//啟動的命令
$action = '/usr/local/php5/bin/php xxxxxx.php';
$logPath = '/tmp/logs/';


do {
 $result = array($result = array( );
 exec("ps aux | grep 'xxxxxx.php'", $result);

 $isOk = 0;
 foreach ($result as $v) {
  $is = strpos($v, $action)($v, $action) ;
  if (false !== $is) {
   $isOk++;
  }
 }

 $exec = $action . " > " . $logPath . "xxx_xxx;   exec($exec);
 }
 sleep(5);
} while (true);

把這個程式也在後台啟動起來,它就會每一個 (true);

把這個程式也在後台啟動起來,它就會每一個隔5秒鐘用ps指令檢查下工作的程式是否存在,不在或不足5個的時候,就啟動到5個。當然這份工作也可以交給維運用shell來做,不過當維運能力不足的時候就得自己來了。

4、多進程

      工作的php為了增加效率,一般情況下會同時啟動多個,甚至是運行在多台機器上。這個時候就要考慮到多進程同時處理同一個資料的問題。這時候一般我會吧任務做一個隊列(一般用redis,這個性能蠻不錯的,怎麼做,大家還是google吧),然後工作程序每次pop出一條要工作的記錄,比如你有一個很大的文件要處理,這時候我通常把文件處理好,一條一條的放到redis的list裡,這樣工作的程序就可以多個程序一起pop,並行執行,而且不會重複。如果實在沒有redis,可以用mysql做,建個innodb的表,程式處理的之前務必在要處理的數據上加個讀鎖,然後處理之後加標記,或者直接刪掉那條數據,這樣也可以實現多進程不重複的問題。

5、日誌

     後台的程序一般會一直跑的,基本上不出事沒人會理它,所以日誌異常重要,因為一旦出事了,需要靠日誌來找原因的,不像前台的程序可以echo看看錯在哪裡。日誌不要怕記的多,不要怕浪費空間,硬碟不值錢的,但是一個bug可能會直接影響你的收入。我通常會這樣記日誌

[機器ip] [進程pid] [時間] [目前程式檔案名稱] [檔案行數] [必要的參數和資訊] [其他]

這些是正常的程式中能想到的問題,一般還會在程序的最外層加個try catch,這樣能夠捕捉大部分的異常,然後也記錄下來(警告catch不到,挺鬱悶的)

6、性能優化

     像這種後台的程序,一般運維都會單獨給機器,這個時候需要做下壓力測試,看看機器究竟能跑幾個進程,這個一般在處理程序狂處理任務的時候看看機器的cpu,內存,網絡,以及硬碟的使用情況,最好是這些同時達到最大值,這樣你的這台機器就不浪費了,如果硬碟使用率很高,其他的很低,就要優化程序,這個情況一般是吧讀取和寫入的資料在記憶體中暫存一段時間,然後一次寫入硬碟;如果cpu狂高,那就是你的演算法太搓了,優化優化吧;記憶體和網路一般不會成為瓶頸,php用不了多少內存,伺服器至少也得是個千兆的網卡吧,這兩項一般不會是瓶頸。所以這些機器我通常會再開個memcache,哈哈,不浪費。

7、題外話🎜

    一個關於伺服器close_wait的問題。 php的程式設計師通常都不太嚴謹,很少有人開了鏈接之後會主動關閉連接的,比如連數據庫,連memcache,很多程式設計師都是建鏈接,操作,然後程式執行完成。如果php不主動關閉連接,會導致對方的機器一直會等待這邊的關閉操作,在對方伺服器上看到的就是一個close_wait狀態,而一台機器能開的連結也就那麼6萬多個,尤其是後台的程式跑起來之後,對方的機器很快就被佔滿了,然後連不上。這時候2邊都需要做些修改,一方面php要主動斷開連接,另一方面對方的機器,需要吧close_wait的預設超時時間改短一點(怎麼改?自己google去),我一般memcache的只有5秒,資料庫的長點,也就2分鐘。這樣處理之後,伺服器的持續性就大大增加了,並發能力也會提高。


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn