php寫後端運行程式總結

來源:互聯網
上載者:User
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
<?php

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


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

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

$exec = $action . " > " . $logPath . "xxxxxx_log &";
for ($i=1;$i<=(5-$isOk);$i++) {
exec($exec);
}
sleep(5);
} while (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分鐘。這樣處理之後,伺服器的持久性就大大增加了,並發能力也會提高。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.