PHP使用gearman進(jìn)行異步的郵件或短信發(fā)送操作詳解
本文實(shí)例講述了PHP使用gearman進(jìn)行異步的郵件或短信發(fā)送操作。分享給大家供大家參考,具體如下:
一、準(zhǔn)備工作
1、為了防止,處理業(yè)務(wù)途中出現(xiàn)的宕機(jī),請(qǐng)配置好gearman的持久化方式。
2、使用gearmanManager來(lái)管理我們的worker腳本,方便測(cè)試。
上述兩條請(qǐng)看我之前寫(xiě)的兩篇文章
二、編寫(xiě)測(cè)試腳本
sendEmail.php代碼如下:
<?php
//注意函數(shù)名與文件名相同
function sendEmail($job) {
$workId = uniqid();
//workload()獲取客戶端發(fā)送來(lái)的序列化數(shù)據(jù)
$data = json_decode($job->workload(), true);
//這里模擬處理過(guò)程
//具體的業(yè)務(wù),這里應(yīng)該是請(qǐng)求發(fā)送郵件的接口,這里只做演示
sleep(1);
echo "workId: {$workId} 發(fā)送 {$data['email']} 成功\n";
}
client.php代碼如下:
<?php
//創(chuàng)建一個(gè)客戶端
$client = new GearmanClient();
//添加一個(gè)job服務(wù)
$client->addServer('127.0.0.1', 4730);
$cnt = 5000;
$ret = array();
//循環(huán)發(fā)送5000條郵件
for($i = 0; $i < $cnt; ++$i) {
//doBackground異步,返回提交任務(wù)的句柄
$ret[$i] = $client->doBackground('sendEmail', json_encode(array(
'email' => "{$i}@qq.com",
'title' => "郵件標(biāo)題{$i}",
'body' => "我是內(nèi)容{$i}",
)));
}
三、修改gearmanManager中配置信息
我的gearmanManager是安裝在/data/GearmanManager/下
> vi /data/GearmanManager/etc/GearmanManager.ini
添加如下信息,我們?yōu)閟endEmail啟動(dòng)五個(gè)進(jìn)程
[sendEmail] ;指定5個(gè)進(jìn)程 dedicated_count=5 ;5個(gè)進(jìn)程都只做sendEmail工作 dedicated_only=1
四、啟動(dòng)gearman
> gearmand -d -q mysql \ --mysql-host=192.168.1.100 \ --mysql-port=3306 \ --mysql-user=gearman \ --mysql-password=123456 \ --mysql-db=gearman \ --mysql-table=gearman_queue &
五、啟動(dòng)gearmanManager
> cd /data/GearmanManager > ./bin/pecl_manager.php -c /data/GearmanManager/etc/GearmanManager.ini -vvv

六、運(yùn)行client.php
> /data/php56/bin/php /data/client.php

當(dāng)我們對(duì)pecl_manager.php進(jìn)行ctrl+c時(shí),強(qiáng)行關(guān)閉worker,client.php那邊仍可正常的發(fā)送請(qǐng)求,不過(guò)數(shù)據(jù)都被保存在了mysql中。
當(dāng)我們重新把worker啟動(dòng)時(shí),gearman會(huì)重新載入沒(méi)有處理的進(jìn)行處理。

我的mysql是裝在主機(jī)的,虛擬機(jī)里裝了gearman,如果有朋友發(fā)現(xiàn)gearman無(wú)法連接mysql,可暫時(shí)關(guān)閉win10防火墻,和開(kāi)啟win10被ping的回顯。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP進(jìn)程與線程操作技巧總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門(mén)教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP實(shí)現(xiàn)的簡(jiǎn)單操作SQLite數(shù)據(jù)庫(kù)類與用法示例
這篇文章主要介紹了PHP實(shí)現(xiàn)的簡(jiǎn)單操作SQLite數(shù)據(jù)庫(kù)類與用法,結(jié)合具體實(shí)例形式分析了php封裝的針對(duì)SQLite數(shù)據(jù)庫(kù)相關(guān)增刪改查操作技巧與使用方法,需要的朋友可以參考下2017-06-06
php 防止單引號(hào),雙引號(hào)在接受頁(yè)面轉(zhuǎn)義
在使用php的過(guò)程中,我們需要使用單引號(hào)和雙引號(hào),所以需要轉(zhuǎn)義一下2008-07-07
PHP利用ueditor實(shí)現(xiàn)上傳圖片添加水印
在上傳圖片時(shí),有時(shí)需要添加水印。如果每個(gè)都用PS添加的話,會(huì)有些麻煩。本文將為大家介紹PHP如何利用ueditor實(shí)現(xiàn)上傳圖片添加水印,感興趣的可以了解一下2022-07-07

