伺服器的存取壓力比較大時,我們可以透過負載平衡來將負載分散到多台伺服器上.但有些比較耗時的請求.例如:
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中文網其他相關文章!