溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何安裝與使用GearmanManager

發(fā)布時間:2021-04-06 16:18:52 來源:億速云 閱讀:113 作者:Leah 欄目:開發(fā)技術

本篇文章為大家展示了如何安裝與使用GearmanManager,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

一、gearman自帶了一個gearadmin工具

查看幫助信息

> gearadmin --help

查看狀態(tài)

> gearadmin --status

查看worker信息

> gearadmin --workers

二、為什么要用GearmanManager

為什么要用GearmanManager來管理我們的worker,因為我們用php編寫的worker是要常駐后臺運行的。
而且一旦worker過多時,代碼更新,難道要一個一個手動重啟,顯然這是很麻煩的。如果中途出現(xiàn)意外中斷或內存泄漏也不好管理。

網(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];
}

當然還有面向對象式的代碼如下:

<?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 調試信息
-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

如何安裝與使用GearmanManager

如何安裝與使用GearmanManager

上述內容就是如何安裝與使用GearmanManager,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI