zoukankan      html  css  js  c++  java
  • tp5消息队列使用

    composer 安装 扩展包

    composer require topthink/think-queue

    注意版本:默认安装5.1的扩展包

    地址: 

    https://packagist.org/packages/topthink/think-queue#v1.1.4

     仔细看官方示例即可.....

    新建队列文件

    <?php 
    namespace appadmincontroller;
    
    
    use thinkqueueJob;
    use thinkDb;
    
    class Work{
        
     public function fire(Job $job, $data) 
        {
            $isJobDone = $this->send($data);       
            if ($isJobDone) {
                //成功删除任务
                $job->delete();
            } else {
                //任务轮询4次后删除
                if ($job->attempts() > 3) {              
                    // 第1种处理方式:重新发布任务,该任务延迟10秒后再执行
                    //$job->release(10); 
                    // 第2种处理方式:原任务的基础上1分钟执行一次并增加尝试次数
                    //$job->failed();   
                    // 第3种处理方式:删除任务
                    $job->delete();  
                }
            }
        }
    
        /**
         * 根据消息中的数据进行实际的业务处理
         * @param array|mixed    $data     发布任务时自定义的数据
         * @return boolean                 任务执行的结果
         */
        private function send($data) 
        {
              $result =  Db::name('order_queue')->insert([
                'utime' =>time(),
                'email' =>$data
              ]);
            if ($result) {
                return true;
            } else {
                return false;
            }            
        }
    }
    
    
     ?>

    业务文件:

    public function queue()
        {
            // 	hinkQueue::push('appadmincontrollerQueue@fire', '284560@qq.com', $queue = '777');
            // 	hinkQueue::push('appcommonqueueQueueClient@sendMAIL', '28456049@qq.com', $queue = null);
            	hinkQueue::push('appadmincontrollerWork@fire', '28456049@qq.com', $queue = '好队列');
                    echo 'ok';
        }

    后台监听:

    php think queue:listen
  • 相关阅读:
    vuex之store拆分即多模块状态管理
    vue项目中使用vueX
    vue中父子组件的参数传递和应用
    VUE中使用vue-awesome-swiper
    VUE真实项目中常用的生命周期和参数
    VUE生命周期
    vue+mockjs 模拟数据,请求回调的应用
    Vue项目搭建与部署还有调试插件Vue.js devtools
    tableTD中添加对角斜线
    前端面试题及答案,理论知识
  • 原文地址:https://www.cnblogs.com/boundless-sky/p/8340706.html
Copyright © 2011-2022 走看看