首頁 >後端開發 >PHP問題 >php如何處理耗時任務

php如何處理耗時任務

(*-*)浩
(*-*)浩原創
2019-09-30 15:30:453322瀏覽

php如何處理耗時任務

伺服器的存取壓力比較大時,我們可以透過負載平衡來將負載分散到多台伺服器上.但有些比較耗時的請求.例如:

1. 需要連接郵件伺服器,發送一封超長的HTML郵件。 (推薦學習:PHP影片教學

2. 需要對使用者上傳的圖片進行裁剪,產生多份縮圖。

3. 需要將使用者上傳的檔案分發到多台伺服器上。

在我們的日常應用中經常遇到,用戶需要等待一段時間,這個請求才能完成,在用戶上傳照片時,照片上傳成功後,然後是裁剪,最後生成縮圖,在這麼一個過程中,使用者只能等待,所以對使用者的體驗來講是相當不好的。

可能在使用者第一次使用過後,下次就很難再讓他使用這個圖片的上傳功能了。

那麼有沒有一種方法將這些處理過程放在後台慢慢運作呢?

答案是肯定的,透過分散式處理可以將這些比較耗時的任務放在後台,甚至分散到多台伺服器上去處理,對於這個問題非同步處理就派上了用場。

現在有很多開源的軟體能實現非同步通信,例如ActiveMQ、Hadoop、Gearman和MecacheMQ等,它們巧妙的將計算轉移到其他伺服器上,而這一切都是隱藏在API中,同時,這些機制都是跨語言的,可以用PHP來指派一個任務,然後將後台的C/C 程式來處理,這一切都不是什麼問題。

下面透過php和Gearman來示範非同步的處理過程.

一、Gearman的安裝

tar zxvf gearmand-0.11.tar.gz
cd  gearmand-0.11
./configure --prefix=/usr/local/gearman
make
make install

二、安裝Gearman PHP extension.

 tar zxf gearman-0.6.0.tgz
cd gearman-0.6.0
  phpize
  ./configure
  make

將module目錄上的gearman.so拷貝到php的module目錄下,我機器的目錄在/usr/lib/php5/20060613 lfs/.

cp module/gearman.so /usr/lib/php5/20060613 lfs/.

然後在php.ini中加入

extension = “gearman.so”

最後重啟apache伺服器.

三、啟動Gearman服務

cd /usr/local/gearman/sbin
./gearman -d -u root

Job的預設連接埠為4730,可以透過

[root@serv_1 sbin]# netstat -nl | grep 4730
tcp        0      0 :::4730                     :::*                        LISTEN

是否啟動.

透過bin/ gearman這個工具,我們可以來體驗Gearman的功能.

啟動Worker:

./gearman -w -f wc -- wc -l &
[1] 2547

運行Client:

./gearman -f wc < /etc/passwd
38

上面的例子中,Worker中定義了一個函數wc,主要功能用來統計文本的行數,而client將/etc/passwd這個文件的內容傳給Worker來處理,最後得出passwd有38行文本.

以上是php如何處理耗時任務的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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