gearman管理工具GearmanManager的安裝與php使用方法示例
本文實(shí)例講述了gearman管理工具GearmanManager的安裝與php使用方法。分享給大家供大家參考,具體如下:
一、gearman自帶了一個(gè)gearadmin工具
查看幫助信息
> gearadmin --help
查看狀態(tài)
> gearadmin --status
查看worker信息
> gearadmin --workers
二、為什么要用GearmanManager
為什么要用GearmanManager來管理我們的worker,因?yàn)槲覀冇胮hp編寫的worker是要常駐后臺(tái)運(yùn)行的。
而且一旦worker過多時(shí),代碼更新,難道要一個(gè)一個(gè)手動(dòng)重啟,顯然這是很麻煩的。如果中途出現(xiàn)意外中斷或內(nèi)存泄漏也不好管理。
網(wǎng)上的解決方案一般有如下二種:
1、通過定時(shí)任務(wù)crontab來定時(shí)的重啟worker
2、通過php的pcntl擴(kuò)展,創(chuàng)建多進(jìn)程來運(yùn)行worker,主進(jìn)程監(jiān)控子進(jìn)程,如果子進(jìn)程退出,則重新啟動(dòng)一個(gè)子進(jìn)程來運(yùn)行worker。
三、使用GearmanManager
GearmanManager下載地址:
https://github.com/brianlmoon/GearmanManager/releases
如:GearmanManager-2.1.0.tar.gz
1、我們創(chuàng)建一個(gè)目錄用來存放worker的代碼
> mkdir -p /data/workers
2、然后我們創(chuàng)建一個(gè)sum.php的worker文件,用來處理計(jì)算兩個(gè)數(shù)之和。
sum.php代碼如下:
<?php //注意函數(shù)名與文件名相同 function sum($job) { //workload()獲取客戶端發(fā)送來的序列化數(shù)據(jù) $data = json_decode($job->workload(), true); //計(jì)算并返回結(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); //計(jì)算并返回結(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這兩個(gè)目錄,etc目錄下提供了三個(gè)配置文件
config-advanced.ini 高級(jí)配置 config.ini 簡(jiǎn)單配置 config.php php方式的配置
配置文件說明:
;全局配置 [GearmanManager] ;指定服務(wù)器,可添加多個(gè),用逗號(hào)分割 host=192.168.1.111:4730,192.168.1.222:4730 ;worker文件存放目錄,可添加多個(gè),用逗號(hào)分割 worker_dir=/data/workers ;要加載的worker,默認(rèn)所有 include=* ;運(yùn)行所有worker進(jìn)程數(shù) count=10 ;worker專用進(jìn)程數(shù),比如總數(shù)是10個(gè),有10個(gè)worker,每個(gè)worker一個(gè)進(jìn)程 dedicated_count=1 ;worker最大有效期,單位秒 max_worker_lifetime=3600 ;監(jiān)控worker目錄的代碼更新,發(fā)現(xiàn)代碼更新,則殺掉進(jìn)程,重新加載代碼。 auto_update=1 ;超時(shí)時(shí)間 timeout = 300 ;當(dāng)然我們也可以對(duì)指定的某個(gè)worker進(jìn)行配置 [sum] ;指定5個(gè)進(jìn)程 dedicated_count=5 ;5個(gè)進(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 只記錄啟動(dòng)與關(guān)閉信息 -vv 進(jìn)程的創(chuàng)建與退出信息 -vvv 關(guān)于worker信息和所做工作 -vvvv 調(diào)試信息 -vvvvv 所有信息
如果出現(xiàn)/usr/bin/env: php: 沒有那個(gè)文件或目錄,請(qǐng)把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ù)庫操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- php使用gearman進(jìn)行任務(wù)分發(fā)操作實(shí)例詳解
- python基于json文件實(shí)現(xiàn)的gearman任務(wù)自動(dòng)重啟代碼實(shí)例
- gearman中worker常駐后臺(tái),導(dǎo)致MySQL server has gone away的解決方法
- PHP使用gearman進(jìn)行異步的郵件或短信發(fā)送操作詳解
- gearman + mysql方式實(shí)現(xiàn)持久化操作示例
- PHP并發(fā)多進(jìn)程處理利器Gearman使用介紹
- Gearman::XS在Centos下的編譯安裝方法
- gearman隊(duì)列持久化引發(fā)的問題及解決方法
- gearman的安裝啟動(dòng)及python API使用實(shí)例
- rhel5.7下安裝gearmand及啟動(dòng)的方法
- gearman中任務(wù)的優(yōu)先級(jí)和返回狀態(tài)實(shí)例分析
相關(guān)文章
PHP實(shí)現(xiàn)根據(jù)銀行卡號(hào)判斷銀行
公司業(yè)務(wù)需要用到根據(jù)銀行卡號(hào)查詢銀行卡的相關(guān)信息,如歸屬地,歸屬銀行,卡的種類等,仔細(xì)研究了一番,分享給大家2015-04-04解析PHP獲取當(dāng)前網(wǎng)址及域名的實(shí)現(xiàn)代碼
本篇文章是對(duì)PHP獲取當(dāng)前網(wǎng)址及域名的代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06探討php define()函數(shù)及defined()函數(shù)使用詳解
本篇文章是對(duì)php中define()函數(shù)及defined()函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06php數(shù)組函數(shù)序列之prev() - 移動(dòng)數(shù)組內(nèi)部指針到上一個(gè)元素的位置,并返回該元素值
prev() 函數(shù)把指向當(dāng)前元素的指針移動(dòng)到上一個(gè)元素的位置,并返回該元素值。如果內(nèi)部指針已經(jīng)超過數(shù)組的第一個(gè)元素之前,函數(shù)返回 false2011-10-10在命令行下運(yùn)行PHP腳本[帶參數(shù)]的方法
這里介紹的是在命令行執(zhí)行php腳本的代碼,其實(shí)主要用到的是php.exe,所以注意設(shè)置環(huán)境變量。2010-01-01PHP實(shí)現(xiàn)Snowflake生成分布式唯一ID的方法示例
這篇文章主要給大家介紹了關(guān)于PHP實(shí)現(xiàn)Snowflake生成分布式唯一ID的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08使用php實(shí)現(xiàn)快錢支付功能(涉及到接口)
本篇文章是對(duì)使用php實(shí)現(xiàn)快錢支付功能的代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07淺析PHP中json_encode與json_decode的區(qū)別
這篇文章主要介紹了淺析PHP中json_encode與json_decode的區(qū)別,PHP提供json_encode()和json_decode()函數(shù),前者用于編碼,后者用于解碼。下面來分析下這兩個(gè)函數(shù),感興趣的可以了解一下2020-07-07