gearman管理工具GearmanManager的安裝與php使用方法示例
本文實例講述了gearman管理工具GearmanManager的安裝與php使用方法。分享給大家供大家參考,具體如下:
一、gearman自帶了一個gearadmin工具
查看幫助信息
> gearadmin --help
查看狀態(tài)
> gearadmin --status
查看worker信息
> gearadmin --workers
二、為什么要用GearmanManager
為什么要用GearmanManager來管理我們的worker,因為我們用php編寫的worker是要常駐后臺運行的。
而且一旦worker過多時,代碼更新,難道要一個一個手動重啟,顯然這是很麻煩的。如果中途出現(xiàn)意外中斷或內(nèi)存泄漏也不好管理。
網(wǎng)上的解決方案一般有如下二種:
1、通過定時任務(wù)crontab來定時的重啟worker
2、通過php的pcntl擴(kuò)展,創(chuàng)建多進(jìn)程來運行worker,主進(jìn)程監(jiān)控子進(jìn)程,如果子進(jìn)程退出,則重新啟動一個子進(jìn)程來運行worker。
三、使用GearmanManager
GearmanManager下載地址:
https://github.com/brianlmoon/GearmanManager/releases
如:GearmanManager-2.1.0.tar.gz
1、我們創(chuàng)建一個目錄用來存放worker的代碼
> mkdir -p /data/workers
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=* ;運行所有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、運行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)程形式運行 -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
更多關(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)實例分析
相關(guān)文章
解析PHP獲取當(dāng)前網(wǎng)址及域名的實現(xiàn)代碼
本篇文章是對PHP獲取當(dāng)前網(wǎng)址及域名的代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06探討php define()函數(shù)及defined()函數(shù)使用詳解
本篇文章是對php中define()函數(shù)及defined()函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06php數(shù)組函數(shù)序列之prev() - 移動數(shù)組內(nèi)部指針到上一個元素的位置,并返回該元素值
prev() 函數(shù)把指向當(dāng)前元素的指針移動到上一個元素的位置,并返回該元素值。如果內(nèi)部指針已經(jīng)超過數(shù)組的第一個元素之前,函數(shù)返回 false2011-10-10PHP實現(xiàn)Snowflake生成分布式唯一ID的方法示例
這篇文章主要給大家介紹了關(guān)于PHP實現(xiàn)Snowflake生成分布式唯一ID的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08淺析PHP中json_encode與json_decode的區(qū)別
這篇文章主要介紹了淺析PHP中json_encode與json_decode的區(qū)別,PHP提供json_encode()和json_decode()函數(shù),前者用于編碼,后者用于解碼。下面來分析下這兩個函數(shù),感興趣的可以了解一下2020-07-07