3

导语

Horizon 为 Laravel 提供了基于 Redis 的、拥有美观后台的、代码驱动配置的队列系统。Horizon 让我们可以轻松监控队列系统的关键指标,例如任务吞吐量、运行时间和失败任务等。

Laravel Horizon 是官方的扩展包,配置以及使用很简单,跟着文档就可以。

安装以及配置

  1. composer require laravel/horizon
  2. 安装好之后,发布资源 php artisan vendor:publish --provider="Laravel\Horizon\HorizonServiceProvider"
  3. 配置文件在 config/horizon.php,可以根据需求修改

使用

  1. 运行 php artisan horizon
  2. 访问 you_site.com/horizon 就可以看到后台了
  3. 还有其他命令

    1. 暂停 php artisan horizon:pause
    2. 继续 php artisan horizon:continue
    3. 执行完所有任务后退出 php artisan horizon:terminate

部署

可以看到使用很简单,在部署的时候要注意以下几点

  1. 确保有 failed_jobs 数据表,相关文档可以看这里
  2. 默认情况下,只能在 local 访问,当然我们可以自定义

    1. 首先修改 config/horizon.phpenvironments 配置项。可以看到其中有 localproduction,将 production 修改为线上 .envAPP_ENV 的值
    2. 接下来可以自定义后台的访问策略,使用 Horizon:auth 方法,return true 即可访问,否则返回 403。在 app/Providers/AppServiceProvider.php 中修改如下
public function boot()
{
    Horizon::auth(function ($request) {
        // 这里进行判断,根据需求自行选择

        // 通过认证可以访问
        if (Auth::check()) {
            return true;
        }

        // 指定参数可以访问
        if ($request->input('q') == 'horizon') {
            return true;
        }

    });
}
  1. 使用 Supervisor 进程守护,如果是使用 Laradock,可以使用 php-worker 或者 laravel-horizon 容器。配置如下,根据情况进行修改(可以参考这两篇文章,这里那里)
[program:horizon]
process_name=%(program_name)s
command=php /var/www/you_project_path/artisan horizon
autostart=true
autorestart=true
user=laradock
redirect_stderr=true
stdout_logfile=/var/www/you_project_path/horizon.log
  1. 使用调度任务来生成监控,以便查看运行情况,在 app/Console/Kernel.php 修改如下
protected function schedule(Schedule $schedule)
{
    // $schedule->command('inspire')
    //          ->hourly();
    $schedule->command('horizon:snapshot')->everyFiveMinutes();
}

结语

Laravel Horizon 还有标签以及通知的配置,感兴趣的可以查看文档。


参考资料:官方扩展包 —— 队列系统解决方案:Laravel Horizon


Haoyuqi
469 声望23 粉丝

PHPer