本文實例講述了gearman管理工具GearmanManager的安裝與php使用方法。分享給大家供大家參考,具體如下:
一、gearman自帶了一個gearadmin工具
查看幫助信息
查看狀態
查看worker信息
二、為什么要用GearmanManager
為什么要用GearmanManager來管理我們的worker,因為我們用php編寫的worker是要常駐后臺運行的。
而且一旦worker過多時,代碼更新,難道要一個一個手動重啟,顯然這是很麻煩的。如果中途出現意外中斷或內存泄漏也不好管理。
網上的解決方案一般有如下二種:
1、通過定時任務crontab來定時的重啟worker
2、通過php的pcntl擴展,創建多進程來運行worker,主進程監控子進程,如果子進程退出,則重新啟動一個子進程來運行worker。
三、使用GearmanManager
GearmanManager下載地址:
https://github.com/brianlmoon/GearmanManager/releases
如:GearmanManager-2.1.0.tar.gz
1、我們創建一個目錄用來存放worker的代碼
2、然后我們創建一個sum.php的worker文件,用來處理計算兩個數之和。
sum.php代碼如下:
?php
//注意函數名與文件名相同
function sum($job) {
//workload()獲取客戶端發送來的序列化數據
$data = json_decode($job->workload(), true);
//計算并返回結果
return $data[0] + $data[1];
}
當然還有面向對象式的代碼如下:
?php
//注意類名與文件名相同
class sum {
public function run($job) {
//workload()獲取客戶端發送來的序列化數據
$data = json_decode($job->workload(), true);
//計算并返回結果
return $data[0] + $data[1];
}
}
3、解壓下載的GearmanManager壓縮包
> tar xf GearmanManager-2.1.0.tar.gz
> mv GearmanManager-2.1.0 /data/GearmanManager
> cd /data/GearmanManager
我們只需要關心bin和etc這兩個目錄,etc目錄下提供了三個配置文件
config-advanced.ini 高級配置
config.ini 簡單配置
config.php php方式的配置
配置文件說明:
;全局配置
[GearmanManager]
;指定服務器,可添加多個,用逗號分割
host=192.168.1.111:4730,192.168.1.222:4730
;worker文件存放目錄,可添加多個,用逗號分割
worker_dir=/data/workers
;要加載的worker,默認所有
include=*
;運行所有worker進程數
count=10
;worker專用進程數,比如總數是10個,有10個worker,每個worker一個進程
dedicated_count=1
;worker最大有效期,單位秒
max_worker_lifetime=3600
;監控worker目錄的代碼更新,發現代碼更新,則殺掉進程,重新加載代碼。
auto_update=1
;超時時間
timeout = 300
;當然我們也可以對指定的某個worker進行配置
[sum]
;指定5個進程
dedicated_count=5
;5個進程都只做sum工作
dedicated_only=1
4、我們復制配置文件,并修改成如上所示,并保存
> mv etc/config-advanced.ini etc/GearmanManager.ini
5、運行GearmanManager
> cd /data/GearmanManager
> ./bin/pecl_manager.php -c /data/GearmanManager/etc/GearmanManager.ini -vvv
參數說明如下:
-P 管理進程pid文件所在目錄,配置文件中通過pid_file來指定
-d 以守護進程形式運行
-u 指定守護進程的用戶
-w 指定worker目錄,當然配置文件里有配置,這里可以不用
-c 指定配置文件
-l 指定日志存放目錄,如果沒指定,則輸出到標準輸出stdout
-h 指定服務器,例如: 192.168.1.111:4730,192.168.1.222:4730
-v 只記錄啟動與關閉信息
-vv 進程的創建與退出信息
-vvv 關于worker信息和所做工作
-vvvv 調試信息
-vvvvv 所有信息
如果出現/usr/bin/env: php: 沒有那個文件或目錄,請把php可執行文件加入環境變量
> echo 'export PATH=/data/php56/bin:/data/php56/sbin:$PATH' >> /etc/profile
> source /etc/profile


更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- php使用gearman進行任務分發操作實例詳解
- python基于json文件實現的gearman任務自動重啟代碼實例
- gearman中worker常駐后臺,導致MySQL server has gone away的解決方法
- PHP使用gearman進行異步的郵件或短信發送操作詳解
- gearman + mysql方式實現持久化操作示例
- PHP并發多進程處理利器Gearman使用介紹
- Gearman::XS在Centos下的編譯安裝方法
- gearman隊列持久化引發的問題及解決方法
- gearman的安裝啟動及python API使用實例
- rhel5.7下安裝gearmand及啟動的方法
- gearman中任務的優先級和返回狀態實例分析