php使用redis的有序集合zset實現延遲隊列應用示例
本文實例講述了php使用redis的有序集合zset實現延遲隊列。分享給大家供大家參考,具體如下:
延遲隊列就是個帶延遲功能的消息隊列,相對于普通隊列,它可以在指定時間消費掉消息。
延遲隊列的應用場景:
1、新用戶注冊,10分鐘后發(fā)送郵件或站內信。
2、用戶下單后,30分鐘未支付,訂單自動作廢。
我們通過redis的有序集合zset來實現簡單的延遲隊列,將消息數據序列化,作為zset的value,把消息處理時間作為score,每次通過zRangeByScore獲取一條消息進行處理。
<?php class DelayQueue { protected $prefix = 'delay_queue:'; protected $redis = null; protected $key = ''; public function __construct($queue, $config = []) { $this->key = $this->prefix . $queue; $this->redis = new Redis(); $this->redis->connect($config['host'], $config['port'], $config['timeout']); $this->redis->auth($config['auth']); } public function delTask($value) { return $this->redis->zRem($this->key, $value); } public function getTask() { //獲取任務,以0和當前時間為區(qū)間,返回一條記錄 return $this->redis->zRangeByScore($this->key, 0, time(), ['limit' => [0, 1]]); } public function addTask($name, $time, $data) { //添加任務,以時間作為score,對任務隊列按時間從小到大排序 return $this->redis->zAdd( $this->key, $time, json_encode([ 'task_name' => $name, 'task_time' => $time, 'task_params' => $data, ], JSON_UNESCAPED_UNICODE) ); } public function run() { //每次只取一條任務 $task = $this->getTask(); if (empty($task)) { return false; } $task = $task[0]; //有并發(fā)的可能,這里通過zrem返回值判斷誰搶到該任務 if ($this->delTask($task)) { $task = json_decode($task, true); //處理任務 echo '任務:' . $task['task_name'] . ' 運行時間:' . date('Y-m-d H:i:s') . PHP_EOL; return true; } return false; } } $dq = new DelayQueue('close_order', [ 'host' => '127.0.0.1', 'port' => 6379, 'auth' => '', 'timeout' => 60, ]); $dq->addTask('close_order_111', time() + 30, ['order_id' => '111']); $dq->addTask('close_order_222', time() + 60, ['order_id' => '222']); $dq->addTask('close_order_333', time() + 90, ['order_id' => '333']);
然后,我們寫一個php腳本,用來處理隊列中的任務。
<?php set_time_limit(0); $dq = new DelayQueue('close_order', [ 'host' => '127.0.0.1', 'port' => 6379, 'auth' => '', 'timeout' => 60, ]); while (true) { $dq->run(); usleep(100000); }
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php+redis數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《PHP基本語法入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
Http 1.1 Etag 與 Last-Modified提高php效率
2008-01-01gearman中任務的優(yōu)先級和返回狀態(tài)實例分析
這篇文章主要介紹了gearman中任務的優(yōu)先級和返回狀態(tài),結合實例形式分析了gearman任務的優(yōu)先級以及獲取返回狀態(tài)相關操作技巧,需要的朋友可以參考下2020-02-02