安裝
在此我就不再略過TP6的項目創建過程了,大致就是安裝composer工具,安裝成功以后,再使用composer去創建項目即可。
think-queue 安裝
~~~
composer require topthink/think-queue
~~~
項目中添加驅動配置
我們需要在安裝好的config下找到 queue.php
[](javascript:void(0); "復制代碼")
~~~
<?php
return [
'default' => 'redis',
'connections' => [
'sync' => [
'type' => 'sync',
],
'database' => [
'type' => 'database',
'queue' => 'default',
'table' => 'jobs',
'connection' => null,
],
'redis' => [
'type' => 'redis',
'queue' => 'default',
'host' => '127.0.0.1',
'port' => 6379,
'password' => '',
'select' => 4,
'timeout' => 0,
'persistent' => false,
],
],
'failed' => [
'type' => 'none',
'table' => 'failed_jobs',
],
];
~~~
[](javascript:void(0); "復制代碼")
生產者
[](javascript:void(0); "復制代碼")
~~~
<?php
namespace app\controller;
use app\BaseController;
use think\facade\Queue;
class Index extends BaseController
{
public function queue()
{
//當前任務將由哪個類來負責處理。
//當輪到該任務時,系統將生成一個該類的實例,并默認調用其 fire 方法
$jobHandlerClassName = 'app\Job\Order';
//當前任務歸屬的隊列名稱,如果為新隊列,會自動創建
//php think queue:work --queue orderJobQueue
//php think queue:work --queue orderJobQueue --daemon
$jobQueueName = "orderJobQueue";
//數組數據
$orderData = [
'id' => uniqid(),
'time' => time(),
'message' => 'later message83'
];
//將該任務推送到消息隊列,等待對應的消費者去執行
//這里只是負責將數據添加到相應的隊列名稱的隊列里,消費者與生產者并無聯系
//立即執行
$isPushed = Queue::push($jobHandlerClassName, $orderData, $jobQueueName);
//延遲10秒后執行
//$isPushed = Queue::later(10, $jobHandlerClassName, $orderData, $jobQueueName);
if ($isPushed !== false) {
echo date('Y-m-d H:i:s') . " 隊列添加成功";
} else {
echo '隊列添加失敗';
}
}
}
~~~
[](javascript:void(0); "復制代碼")
消費者
[](javascript:void(0); "復制代碼")
~~~
<?php
namespace app\Job;
use think\facade\Log;
use think\queue\Job;
/**
* @Title: app\task\job$Order
* @Package package_name
* @Description: todo(測試訂單消費者)
* @author Jack
*/
class Order
{
/**
* @Title: fire
* @Description: todo(fire方法是消息隊列默認調用的方法)
* @param Job $job
* @param array $data
* @author Jack
* @throws
*/
public function fire(Job $job, array $data)
{
//有些消息在到達消費者時,可能已經不再需要執行了
$isJobStillNeedToBeDone = $this->checkDatabaseToSeeIfJobNeedToBeDone($data);
if(!$isJobStillNeedToBeDone){
$job->delete();
return;
}
$jobId = $job->getJobId();
$isJobDone = $this->orders($data, $jobId);
if ($isJobDone) {
//如果任務執行成功,記得刪除任務
$job->delete();
} else {
//通過這個方法可以檢查這個任務已經重試了幾次了
if ($job->attempts() > 3){
Log::error('試了3次了');
$job->delete();
//也可以重新發布這個任務
//print("<info>Hello Job will be availabe again after 2s."."</info>\n");
//$job->release(2); //$delay為延遲時間,表示該任務延遲2秒后再執行
}
}
}
/**
* @Title: checkDatabaseToSeeIfJobNeedToBeDone
* @Description: todo(有些消息在到達消費者時,可能已經不再需要執行了)
* @param array $data
* @return boolean
* @author Jack
* @throws
*/
private function checkDatabaseToSeeIfJobNeedToBeDone($data)
{
return true;
}
/**
* @Title: orders
* @Description: todo(數據處理)
* @param array $data
* @author Jack
* @throws
*/
public function orders(array $data, $jobId)
{
//對訂單進行數據庫操作或其他等等
Log::info(date('Y-m-d H:i:s') . ' - data:' . json_encode($data));
return true;
}
}
~~~
[](javascript:void(0); "復制代碼")
服務器執行常駐命令
~~~
php think queue:work --queue orderJobQueue
~~~
- thinkphp6執行流程(一)
- php中use關鍵字用法詳解
- Thinkphp6使用騰訊云發送短信步驟
- 路由配置
- Thinkphp6,static靜態資源訪問路徑問題
- ThinkPHP6.0+ 使用Redis 原始用法
- smarty在thinkphp6.0中的最佳實踐
- Thinkphp6.0 搜索器使用方法
- 從已有安裝包(vendor)恢復 composer.json
- tp6with的用法,表間關聯查詢
- thinkphp6.x多對多如何添加中間表限制條件
- thinkphp6 安裝JWT
- 緩存類型
- 請求信息和HTTP頭信息
- 模型事件用法
- 助手函數匯總
- tp6集成Alipay 手機和電腦端支付的方法
- thinkphp6使用jwt
- 6.0session cookie cache
- tp6筆記
- TP6(thinkphp6)隊列與延時隊列
- thinkphp6 command(自定義指令)
- command(自定義指令)
- 本地文件上傳
- 緩存
- 響應
- 公共函數配置
- 七牛云+文件上傳
- thinkphp6:訪問多個redis數據源(thinkphp6.0.5 / php 7.4.9)
- 富文本編輯器wangEditor3
- IP黑名單
- 增刪改查 +文件上傳
- workerman 定時器操作控制器的方法
- 上傳文件到阿里云oss
- 短信或者郵箱驗證碼防刷代碼
- thinkphp6:訪問redis6(thinkphp 6.0.9/php 8.0.14)
- 實現關聯多個id以逗號分開查詢數據
- thinkphp6實現郵箱注冊功能的細節和代碼(點擊鏈接激活方式)
- 用mpdf生成pdf文件(php 8.1.1 / thinkphp v6.0.10LTS )
- 生成帶logo的二維碼(php 8.1.1 / thinkphp v6.0.10LTS )
- mysql數據庫使用事務(php 8.1.1 / thinkphp v6.0.10LTS)
- 一,創建過濾IP的中間件
- 源碼解析請求流程
- 驗證碼生成
- 權限管理
- 自定義異常類
- 事件監聽event-listene
- 安裝與使用think-addons
- 事件與多應用
- Workerman 基本使用
- 查詢用戶列表按拼音字母排序
- 擴展包合集
- 查詢用戶數據,但是可以通過輸入用戶昵稱來搜索用戶同時還要統計用戶的文章和粉絲數
- 根據圖片的minetype類型獲取文件真實拓展名思路
- 到處excel
- 用imagemagick庫生成縮略圖
- 生成zip壓縮包并下載
- API 多版本控制
- 用redis+lua做限流(php 8.1.1 / thinkphp v6.0.10LTS )
- 【thinkphp6源碼分析三】 APP類之父, 容器Container類
- thinkphp6表單重復提交解決辦法
- 小程序授權
- 最簡單的thinkphp6導出Excel
- 根據訪問設備不同訪問不同模塊
- 服務系統
- 前置/后置中間件
- 給接口api做簽名驗證(php 8.1.1 / thinkphp v6.0.10LTS )
- 6實現郵箱注冊功能的細節和代碼(點擊鏈接激活方式)
- 使用前后端分離的驗證碼(thinkphp 6.0.9/php 8.0.14/vue 3.2.26)
- 前后端分離:用jwt+middleware做用戶登錄驗證(php 8.1.1 / thinkphp v6.0.10LTS )
- vue前后端分離多圖上傳
- thinkphp 分組、頁面跳轉與ajax
- thinkphp6 常用方法文檔
- 手冊里沒有的一些用法
- Swagger 3 API 注釋
- PHP 秒級定時任務
- thinkphp6集成gatewayWorker(workerman)實現實時監聽
- thinkphp6按月新增數據表
- 使用redis 實現消息隊列
- api接口 統一結果返回處理類
- 使用swoole+thinkphp6.0+redis 結合開發的登錄模塊
- 給接口api做簽名驗證
- ThinkPHP6.0 + UniApp 實現小程序的 微信登錄
- ThinkPHP6.0 + Vue + ElementUI + axios 的環境安裝到實現 CURD 操作!
- 異常$e
- 參數請求驗證自定義和異常錯誤自定義