本文實例講述了gearman管理工具GearmanManager的安裝與php使用方法。分享給大家供大家參考,具體如下:
一、gearman自帶了一個gearadmin工具
查看幫助信息
查看狀態(tài)
查看worker信息
二、為什么要用GearmanManager
為什么要用GearmanManager來管理我們的worker,因為我們用php編寫的worker是要常駐后臺運(yùn)行的。
而且一旦worker過多時,代碼更新,難道要一個一個手動重啟,顯然這是很麻煩的。如果中途出現(xiàn)意外中斷或內(nèi)存泄漏也不好管理。
網(wǎng)上的解決方案一般有如下二種:
1、通過定時任務(wù)crontab來定時的重啟worker
2、通過php的pcntl擴(kuò)展,創(chuàng)建多進(jìn)程來運(yùn)行worker,主進(jìn)程監(jiān)控子進(jìn)程,如果子進(jìn)程退出,則重新啟動一個子進(jìn)程來運(yùn)行worker。
三、使用GearmanManager
GearmanManager下載地址:
https://github.com/brianlmoon/GearmanManager/releases
如:GearmanManager-2.1.0.tar.gz
1、我們創(chuàng)建一個目錄用來存放worker的代碼
2、然后我們創(chuàng)建一個sum.php的worker文件,用來處理計算兩個數(shù)之和。
sum.php代碼如下:
?php
//注意函數(shù)名與文件名相同
function sum($job) {
//workload()獲取客戶端發(fā)送來的序列化數(shù)據(jù)
$data = json_decode($job->workload(), true);
//計算并返回結(jié)果
return $data[0] + $data[1];
}
當(dāng)然還有面向?qū)ο笫降拇a如下:
?php
//注意類名與文件名相同
class sum {
public function run($job) {
//workload()獲取客戶端發(fā)送來的序列化數(shù)據(jù)
$data = json_decode($job->workload(), true);
//計算并返回結(jié)果
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
我們只需要關(guān)心bin和etc這兩個目錄,etc目錄下提供了三個配置文件
config-advanced.ini 高級配置
config.ini 簡單配置
config.php php方式的配置
配置文件說明:
;全局配置
[GearmanManager]
;指定服務(wù)器,可添加多個,用逗號分割
host=192.168.1.111:4730,192.168.1.222:4730
;worker文件存放目錄,可添加多個,用逗號分割
worker_dir=/data/workers
;要加載的worker,默認(rèn)所有
include=*
;運(yùn)行所有worker進(jìn)程數(shù)
count=10
;worker專用進(jìn)程數(shù),比如總數(shù)是10個,有10個worker,每個worker一個進(jìn)程
dedicated_count=1
;worker最大有效期,單位秒
max_worker_lifetime=3600
;監(jiān)控worker目錄的代碼更新,發(fā)現(xiàn)代碼更新,則殺掉進(jìn)程,重新加載代碼。
auto_update=1
;超時時間
timeout = 300
;當(dāng)然我們也可以對指定的某個worker進(jìn)行配置
[sum]
;指定5個進(jìn)程
dedicated_count=5
;5個進(jìn)程都只做sum工作
dedicated_only=1
4、我們復(fù)制配置文件,并修改成如上所示,并保存
> mv etc/config-advanced.ini etc/GearmanManager.ini
5、運(yùn)行GearmanManager
> cd /data/GearmanManager
> ./bin/pecl_manager.php -c /data/GearmanManager/etc/GearmanManager.ini -vvv
參數(shù)說明如下:
-P 管理進(jìn)程pid文件所在目錄,配置文件中通過pid_file來指定
-d 以守護(hù)進(jìn)程形式運(yùn)行
-u 指定守護(hù)進(jìn)程的用戶
-w 指定worker目錄,當(dāng)然配置文件里有配置,這里可以不用
-c 指定配置文件
-l 指定日志存放目錄,如果沒指定,則輸出到標(biāo)準(zhǔn)輸出stdout
-h 指定服務(wù)器,例如: 192.168.1.111:4730,192.168.1.222:4730
-v 只記錄啟動與關(guān)閉信息
-vv 進(jìn)程的創(chuàng)建與退出信息
-vvv 關(guān)于worker信息和所做工作
-vvvv 調(diào)試信息
-vvvvv 所有信息
如果出現(xiàn)/usr/bin/env: php: 沒有那個文件或目錄,請把php可執(zhí)行文件加入環(huán)境變量
> echo 'export PATH=/data/php56/bin:/data/php56/sbin:$PATH' >> /etc/profile
> source /etc/profile
![](/d/20211017/a9ddfba7a9fcb3942392236044aeaada.gif)
![](/d/20211017/02a4f1bf22f3737fd65a4e9ce6ed6554.gif)
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP進(jìn)程與線程操作技巧總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- php使用gearman進(jìn)行任務(wù)分發(fā)操作實例詳解
- python基于json文件實現(xiàn)的gearman任務(wù)自動重啟代碼實例
- gearman中worker常駐后臺,導(dǎo)致MySQL server has gone away的解決方法
- PHP使用gearman進(jìn)行異步的郵件或短信發(fā)送操作詳解
- gearman + mysql方式實現(xiàn)持久化操作示例
- PHP并發(fā)多進(jìn)程處理利器Gearman使用介紹
- Gearman::XS在Centos下的編譯安裝方法
- gearman隊列持久化引發(fā)的問題及解決方法
- gearman的安裝啟動及python API使用實例
- rhel5.7下安裝gearmand及啟動的方法
- gearman中任務(wù)的優(yōu)先級和返回狀態(tài)實例分析