zoukankan      html  css  js  c++  java
  • laravel中redis队列的使用

    一、配置文件
    
    首先我们需要在配置文件中配置默认队列驱动为Redis,队列配置文件是config/queue.php:
    return [
     
        'default' => env('QUEUE_DRIVER', 'sync'),
     
        'connections' => [
            'sync' => [
                'driver' => 'sync',
            ],
            'database' => [
                'driver' => 'database',
                'table' => 'jobs',
                'queue' => 'default',
                'expire' => 60,
            ],
            'beanstalkd' => [
                'driver' => 'beanstalkd',
                'host' => 'localhost',
                'queue' => 'default',
                'ttr' => 60,
            ],
            'sqs' => [
                'driver' => 'sqs',
                'key' => 'your-public-key',
                'secret' => 'your-secret-key',
                'queue' => 'your-queue-url',
                'region' => 'us-east-1',
            ],
            'iron' => [
                'driver' => 'iron',
                'host' => 'mq-aws-us-east-1.iron.io',
                'token' => 'your-token',
                'project' => 'your-project-id',
                'queue' => 'your-queue-name',
                'encrypt' => true,
            ],
            'redis' => [
                'driver' => 'redis',
                'connection' => 'default',
                'queue' => 'default',
                'expire' => 60,
            ],
        ],
     
        'failed' => [
            'database' => 'mysql', 'table' => 'failed_jobs',
        ],
    ];
    该配置文件第一个配置项default用于指定默认的队列驱动,这里我们将其值改为redis(实际上是修改.env中的QUEUE_DRIVER)。
    二、编写队列任务
    
    首先我们通过如下Artisan命令创建任务类:
    php artisan make:job SendReminderEmail
      运行成功后会在app/Jobs目录下生成一个SendReminderEmail.php,我们修改其内容如下:
    <?php
    namespace AppJobs;
     
    use AppJobsJob;
    use IlluminateQueueSerializesModels;
    use IlluminateQueueInteractsWithQueue;
    use IlluminateContractsBusSelfHandling;
    use IlluminateContractsQueueShouldQueue;
    use AppUser;
    use IlluminateContractsMailMailer;
    class SendReminderEmail extends Job implements SelfHandling, ShouldQueue
    {
     
        use InteractsWithQueue, SerializesModels;
        protected $user;
         
        /**
         * Create a new job instance.
         *
         * @return void
         */
     
        public function __construct(User $user)
        {
            $this->user = $user;
        }
     
        /**
         * Execute the job.
         *
         * @return void
         */
        public function handle(Mailer $mailer)
        {
            $user = $this->user;
            $mailer->send('emails.reminder',['user'=>$user],function($message) use ($user){
                $message->to($user->email)->subject('新功能发布');
            });
        }
    }
    
    
    
    三、推送队列任务
    手动分发任务
    我们可以使用控制器中的DispatchesJobs trait(该trait在控制器基类Controller.php中引入)提供的dispatch方法手动分发任务:
    
    //在控制器中use
    use AppJobsSendReminderEmail;
     接着直接调用就是了
    $user = AppUser::findOrFail($id);
    $this->dispatch(new SendReminderEmail($user));
      
    四、运行队列监听器
    在浏览器中访问http://laravel.app:8000/mail/sendReminderEmail/1,此时任务被推送到Redis队列中,我们还需要在命令行中运行Artisan命令执行队列中的任务。Laravel为此提供了三种Artisan命令:
    
    queue:work 默认只执行一次队列请求, 当请求执行完成后就终止;
    queue:listen 监听队列请求,只要运行着,就能一直接受请求,除非手动终止;
    queue:work --daemon 同 listen 一样, 只要运行着,就能一直接受请求,不一样的地方是在这个运行模式下,当新的请求到来的时候,不重新加载整个框架,而是直接 fire 动作。能看出来, queue:work --daemon是最高级的,一般推荐使用这个来处理队列监听。
    注:使用 queue:work --daemon ,当更新代码的时候,需要停止,然后重新启动,这样才能把修改的代码应用上。
    
    所以我们接下来在命令行中运行如下命令:
    php artisan queue:work --daemon
  • 相关阅读:
    jmeter跨平台执行时的文件路径问题
    jenkins配置
    jmeter--负载测试
    jmeter-脚本制作
    jmeter学习-性能指标、jmeter初识
    功能测试--其他
    功能测试--Fiddler
    功能测试--APP专项
    功能测试--基础(二)
    功能测试-基础(一)
  • 原文地址:https://www.cnblogs.com/sgm4231/p/9916819.html
Copyright © 2011-2022 走看看