詳解PHP使用gearman進行非同步的郵件或簡訊傳送操作

2020-07-16 10:05:59

本文範例講述了PHP使用gearman進行非同步的郵件或簡訊傳送操作。分享給大家供大家參考,具體如下:

一、準備工作

1、為了防止,處理業務途中出現的宕機,請設定好gearman的持久化方式。
2、使用gearmanManager來管理我們的worker指令碼,方便測試。

二、編寫測試指令碼

sendEmail.php程式碼如下:

<?php
//注意函數名與檔名相同
function sendEmail($job) {
  $workId = uniqid();

  //workload()獲取用戶端傳送來的序列化資料
  $data = json_decode($job->workload(), true);
  
  //這裡模擬處理過程
  //具體的業務,這裡應該是請求傳送郵件的介面,這裡只做演示
  sleep(1);
  
  echo "workId: {$workId} 傳送 {$data['email']} 成功n";
}

client.php程式碼如下:

<?php
//建立一個用戶端
$client = new GearmanClient();
//新增一個job服務
$client->addServer('127.0.0.1', 4730);

$cnt = 5000;
$ret = array();

//迴圈傳送5000條郵件
for($i = 0; $i < $cnt; ++$i) {
  //doBackground非同步,返回提交任務的控制代碼
  $ret[$i] = $client->doBackground('sendEmail', json_encode(array(
    'email' => "{$i}@qq.com",
    'title' => "郵件標題{$i}",
    'body' => "我是內容{$i}",
  )));
}

三、修改gearmanManager中設定資訊

我的gearmanManager是安裝在/data/GearmanManager/下

> vi /data/GearmanManager/etc/GearmanManager.ini

新增如下資訊,我們為sendEmail啟動五個進程

[sendEmail]
;指定5個進程
dedicated_count=5
;5個進程都只做sendEmail工作
dedicated_only=1

四、啟動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 &

五、啟動gearmanManager

> cd /data/GearmanManager
> ./bin/pecl_manager.php -c /data/GearmanManager/etc/GearmanManager.ini -vvv

六、執行client.php

> /data/php56/bin/php /data/client.php

當我們對pecl_manager.php進行ctrl+c時,強行關閉worker,client.php那邊仍可正常的傳送請求,不過資料都被儲存在了mysql中。
當我們重新把worker啟動時,gearman會重新載入沒有處理的進行處理。


我的mysql是裝在主機的,虛擬機器裡裝了gearman,如果有朋友發現gearman無法連線mysql,可暫時關閉win10防火牆,和開啟win10被ping的回顯。

以上就是詳解PHP使用gearman進行非同步的郵件或簡訊傳送操作的詳細內容,更多請關注TW511.COM其它相關文章!