主頁 > 知識庫 > gearman管理工具GearmanManager的安裝與php使用方法示例

gearman管理工具GearmanManager的安裝與php使用方法示例

熱門標簽:電子圍欄 Linux服務器 Mysql連接數(shù)設置 科大訊飛語音識別系統(tǒng) 服務器配置 阿里云 團購網(wǎng)站 銀行業(yè)務

本文實例講述了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、通過定時任務crontab來定時的重啟worker
2、通過php的pcntl擴展,創(chuàng)建多進程來運行worker,主進程監(jiā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);
 //計算并返回結果
 return $data[0] + $data[1];
}

當然還有面向?qū)ο笫降拇a如下:

?php
//注意類名與文件名相同
class sum {
 public function run($job) {
  //workload()獲取客戶端發(fā)送來的序列化數(shù)據(jù)
  $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進程數(shù)
count=10
;worker專用進程數(shù),比如總數(shù)是10個,有10個worker,每個worker一個進程
dedicated_count=1
;worker最大有效期,單位秒
max_worker_lifetime=3600
;監(jiān)控worker目錄的代碼更新,發(fā)現(xiàn)代碼更新,則殺掉進程,重新加載代碼。
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

參數(shù)說明如下:

-P 管理進程pid文件所在目錄,配置文件中通過pid_file來指定
-d 以守護進程形式運行
-u 指定守護進程的用戶
-w 指定worker目錄,當然配置文件里有配置,這里可以不用
-c 指定配置文件
-l 指定日志存放目錄,如果沒指定,則輸出到標準輸出stdout
-h 指定服務器,例如: 192.168.1.111:4730,192.168.1.222:4730
-v 只記錄啟動與關閉信息
-vv 進程的創(chuàng)建與退出信息
-vvv 關于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

更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網(wǎng)絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • php使用gearman進行任務分發(fā)操作實例詳解
  • python基于json文件實現(xiàn)的gearman任務自動重啟代碼實例
  • gearman中worker常駐后臺,導致MySQL server has gone away的解決方法
  • PHP使用gearman進行異步的郵件或短信發(fā)送操作詳解
  • gearman + mysql方式實現(xiàn)持久化操作示例
  • PHP并發(fā)多進程處理利器Gearman使用介紹
  • Gearman::XS在Centos下的編譯安裝方法
  • gearman隊列持久化引發(fā)的問題及解決方法
  • gearman的安裝啟動及python API使用實例
  • rhel5.7下安裝gearmand及啟動的方法
  • gearman中任務的優(yōu)先級和返回狀態(tài)實例分析

標簽:大理 江蘇 衡水 萍鄉(xiāng) 衢州 蚌埠 廣元 棗莊

巨人網(wǎng)絡通訊聲明:本文標題《gearman管理工具GearmanManager的安裝與php使用方法示例》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266