调度和队列

任务调度

使用 Laravel 的任务调度,可以实现系统计划执行任务。

如何在模块中注册一个任务调度

实现一个任务调度Provider

  1. class ModuleXxxScheduleProvider extends AbstractScheduleProvider
  2. {
  3. public function cron()
  4. {
  5. return $this->cronEveryMinute();
  6. }
  7. public function title()
  8. {
  9. return '测试任务调度';
  10. }
  11. public function run()
  12. {
  13. Log::info('任务已经执行');
  14. }
  15. }

注册任务调度

  1. ScheduleProvider::register(ModuleXxxScheduleProvider::class);

开启调度器

Cron 是 UNIX、SOLARIS、LINUX 下的一个十分有用的工具,通过 Cron 脚本能使计划任务定期地在系统后台自动运行。这种计划任务在 UNIX、SOLARIS、LINUX下术语为 Cron Jobs。

下面是你唯一需要添加到服务器的 Cron 条目:

  1. * * * * * php /xxx/artisan schedule:run >> /dev/null 2>&1

该 Cron 将会每分钟调用一次 Laravel 命令调度器,当 schedule:run 命令执行后,ModStart 和 Laravel 评估你的调度任务并运行到期的任务。

队列

队列的目的是将耗时的任务延时处理,比如发送邮件、文档转换处理等,从而大幅度缩短 Web 请求和响应的时间。

队列配置文件存放在 config/queue.php。每一种队列驱动的配置都可以在该文件中找到,包括数据库、Beanstalkd、Amazon SQS、Redis以及同步(本地使用)驱动。

如何使用 MySQL 作为队列驱动

第一步,生成数据库队列表迁移文件

  1. php artisan queue:table

这一步会生成数据库迁移文件 database/migrations/xxxx_xx_xx_xxxxxx_create_jobs_table.php

第二步,执行数据库迁移文件

  1. php artisan migrate

第三步,在 .env 文件配置队列驱动为数据库

  1. QUEUE_DRIVER=database
  2. QUEUE_CONNECTION=database

第四步,运行队列进程

  1. php /xxx/artisan queue:work database --sleep=3 --tries=3

使用 Supervisor 管理队列进程

如果你使用的是 ssh 运行的队列进程,当 ssh 连接断开时,该进程会自动停止。

Supervisor 是 Linux 系统中常用的进程守护程序,如果队列进程 queue:work 意外关闭,它会自动重启启动队列进程。

Supervisor 参考配置

  1. [program:queue-worker]
  2. process_name=%(program_name)s_%(process_num)02d
  3. command=php /xxx/artisan queue:work database --sleep=3 --tries=3
  4. autostart=true
  5. autorestart=true
  6. user=www
  7. numprocs=2
  8. redirect_stderr=true
  9. stdout_logfile=/tmp/worker.log

command 表示执行的命令 user 表示启动进程的用户 numprocs 可以控制队列进程的数量,即同时执行的任务数