您好,登錄后才能下訂單哦!
本篇文章為大家展示了如何安裝與使用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
上述內容就是如何安裝與使用GearmanManager,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。