gearman管理工具GearmanManager的安裝與使用


一、gearman自帶了一個gearadmin工具

查看幫助信息

> gearadmin --help

查看狀態

> gearadmin --status

查看worker信息

> gearadmin --workers

  

二、為什么要用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的代碼

> mkdir -p /data/workers

  

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM