IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> 延迟任务开发 -> 正文阅读

[PHP知识库]延迟任务开发

AsynDelayQueueService.class.php文件

<?php


namespace App\Tool\AsynQueue\Service;

use Common\Service\RedisService;

/**
 * 异步延时任务
 */
class AsynDelayQueueService
{
    protected $redis;
    protected $queue;

    public function __construct()
    {
        $redis_obj = RedisService::getInstance();
        $this->redis = $redis_obj->redis;
        $this->queue = 'tp3_asyn_delay_queue';
    }

    /**
     * @use_for: 提交任务
     * 任务函数需要bool返回值更新db记录
     * @param int $exec_time 执行时间 时间戳
     * @param $class
     * @param $method
     * @param $method_param
     * @param $class_param
     * @return false|int
     * @date:2022-01-16 20:30
     */
    public function push($exec_time, $class, $method, $method_param = [], $class_param = [])
    {

        if (class_exists($class) === false) {
            return false;
        }
        if (method_exists($class, $method) === false) {
            return false;
        }
        $task_info = [
            'class' => $class,
            'class_param' => $class_param,
            'method' => $method,
            'method_param' => $method_param,
        ];
        $task_info = serialize($task_info);
        $task_id = 'delay_task_id_' . md5($task_info);

        $timeout = $exec_time - time() + 600;
        $this->redis->set($task_id, $task_info, $timeout);
        $result = $this->redis->zAdd($this->queue, $exec_time, $task_id);
        M('asyn_delay_queue_log')->add([
            'task_id' => $task_id,
            'class' => $class,
            'method' => $method,
            'exec_time' => $exec_time,
            'task_info' => $task_info,
        ]);
        return $result;
    }

    /**
     * @use_for: 主进程
     * @return mixed
     * @date:2022-01-16 20:30
     */
    public function run()
    {
        while (true) {
            //0.3s
            usleep(300000);
            $current_time = time();
            $task_id_list = $this->redis->zRangeByScore($this->queue, $current_time - 2, $current_time);
            if (empty($task_id_list)) {
                continue;
            }

            $resource = [];
            foreach ($task_id_list as $task_id) {
                $delete_number = $this->redis->zRem($this->queue, $task_id);
                if (empty($delete_number)) {
                    continue;
                }
                if (empty($this->redis->exists($task_id))) {
                    continue;
                }
                //echo "start task: $task_id" . PHP_EOL;
                //测试并发在200左右
                $resource[] = @proc_open('nohup php cli.php "home/task/asynDelayStart/id/"' . $task_id . ' >/dev/null 2>&1 &',
                    [], $pipes);
            }
            //关闭会阻塞,另找办法处理
            // foreach ($resource as $item) {
            //     @proc_close($item);
            // }
        }
    }

    /**
     * @use_for: 执行子任务
     * @param $task_id
     * @return false|mixed
     * @date:2022-01-16 20:33
     */
    public function start($task_id)
    {
        $task_info = $this->redis->get($task_id);
        if (empty($task_info)) {
            return false;
        }
        $task_info = unserialize($task_info);
        $result = false;
        if (empty($task_info['class'])) {

        } elseif (class_exists($task_info['class']) === false) {

        } elseif (method_exists($task_info['class'], $task_info['method']) === false) {

        } else {
            try {
                if (empty($task_info['class_param'])) {
                    $obj = new $task_info['class']();
                } else {
                    $obj = new $task_info['class'](...$task_info['class_param']);
                }
                $result = call_user_func_array([$obj, $task_info['method']], $task_info['method_param']);
            } catch (\Exception $exception) {
            }
        }
        if ($result === false) {
            $status = 3;
        } else {
            $status = 2;
        }
        M('asyn_delay_queue_log')->where(['task_id' => $task_id])->save([
            'status' => $status,
        ]);
        return $result;
    }


}

task文件

$resource[] = @proc_open(‘nohup php cli.php “home/task/asynDelayStart/id/”’ . $task_id . ’ >/dev/null 2>&1 &’,
[], $pipes);在这里调用asynDelayStart方法

    /**
     * @use_for: 异步延时任务子任务
     *    
     * @param $id
     * @date:2022-01-16 20:36
     */
    public function asynDelayStart($id)
    {
        $asyn_delay_service = new AsynDelayQueueService();
        $asyn_delay_service->start($id);
    }

    /**
     * @use_for: 异步实时任务主任务
     *定时任务每隔10分钟执行一次
     * @date:2022-01-16 20:36
     */
    public function asynTimelyRun()
    {
        $asyn_timely_service = new AsynTimelyQueueService();
        $asyn_timely_service->run();
    }
 //投递开奖倒计时任务
        $service = new AsynDelayQueueService();
        $exec_time = time() + $broadcastData['duration']+10;
        $service->push($exec_time, 'Wechat\Logic\ShakeLotteryLogic', 'doLottery', ['prize_id'=> $broadcastData['prize_id']]);
  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:08:09  更:2022-03-08 22:09:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/26 16:02:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计