Laravel Crontab 支持的最小单位是分钟,怎么实现秒级执行的需求呢?

简介: Laravel Crontab 支持的最小单位是分钟,怎么实现秒级执行的需求呢?

需求描述


今天接到一个需求,每三秒钟给客户端推送一次最新的在线人数。


分析


每三秒钟?要这么频繁吗?之前的最小颗粒度是每分钟哇。

调研了一波发现,我们可以结合异步任务的delay来实现。


核心代码


在 onQueue()函数后面调用 delay()函数

delay指定了延迟多久执行


XxxxxJob::dispatch()
    ->onQueue(QueueNameBuilder::getName(QueueNameBuilder::PUSH_DATING_COUNT))
    ->delay(now()->addSeconds($delay));


需求实现


比如我们的需求是,每三秒钟给客户端推送一次数据。

我的设计是这样的:


异步任务代码


<?php
namespace App\Console\Crontab;
use App\Jobs\PushDatingCountJob;
use App\Model\House\HouseOpen;
use App\Model\Queue\QueueNameBuilder;
class PushDatingCount extends BaseCrontab
{
    const RATE_SECOND = 3; //每三秒发送一次 延迟实现
    public function __invoke()
    {
        $times = 60 / self::RATE_SECOND;
        $delayTimes = [];
        for ($i = 0; $i < $times; $i++) {
            $delayTimes[] = $i * 3;
        }
        foreach ($delayTimes as $delay) {
            PushDatingCountJob::dispatch()
                ->onQueue(QueueNameBuilder::getName(QueueNameBuilder::PUSH_DATING_COUNT))
                ->delay(now()->addSeconds($delay));
        }
    }
}


Kernel


<?php
namespace App\Console;
.
.
.
class Kernel extends ConsoleKernel
{
    /**
     * The Artisan commands provided by your application.
     *
     * @var array
     */
    protected $commands = [
        //
    ];
    /**
     * Define the application's command schedule.
     *
     * @param \Illuminate\Console\Scheduling\Schedule $schedule
     * @return void
     */
    protected function schedule(Schedule $schedule)
    {
        .
        .
        .
        //每分钟执行一次
        $schedule->call(new PushDatingCount())
            ->cron("* * * * *")
            ->name("push_dating_count")
            ->onOneServer();
    }
    /**
     * Register the commands for the application.
     *
     * @return void
     */
    protected function commands()
    {
        $this->load(__DIR__ . '/Commands');
        require base_path('routes/console.php');
    }
}


通过这个思路我们就实现了需求。


更多的使用技巧


本地测试阶段不方面使用异步任务队列怎么办呢?


我们可以使用dispatchNow()


比如:

本地执行,不使用异步队列的情况:


UserConfirmForAdmin::dispatchNow([
            'data' => $data,
            'adminId' => $adminId,
        ]);


使用异步任务队列执行的情况:


UserConfirmForAdmin::dispatch([
            'data' => $data,
            'adminId' => $adminId,
        ])->onQueue(QueueNameBuilder::getName(QueueNameBuilder::USER_CONFIRM_FOR_ADMIN));


如何可视化查询异步任务的执行情况呢?


我们可以使用 horizon

我们通过仪表盘能够非常方便的进行数据监控,查看数据指标,查看最近失败的异步任务,可以通过后台重新执行异步任务


微信图片_20221111233802.jpg


重点说一下执行失败的异步任务,后台是支持查看数据参数的,方便我们定位问题。


微信图片_20221111233806.jpg


相关文章
|
Oracle 关系型数据库 Linux
解决在linux服务器上部署定时自动查找cpu,内存,磁盘使用量,并将查询结果写入数据库的脚本,只能手动运行实现插库操作
问题描述:将脚本名命名为mortior.sh(以下简称mo),手动执行脚本后查询数据库,表中有相应的信息,放入自动执行队列中,脚本被执行,但是查询数据库,并没有新增数据。
92 0
|
Python Windows
Windows定时任务 每隔一段时间(最小到秒级)执行一次指定的Python脚本
Windows定时任务 每隔一段时间(最小到秒级)执行一次指定的Python脚本
Windows定时任务 每隔一段时间(最小到秒级)执行一次指定的Python脚本
|
NoSQL API 调度
.NET开源的轻量化定时任务调度,支持临时的延时任务和重复循环任务(可持久化) - FreeScheduler
.NET开源的轻量化定时任务调度,支持临时的延时任务和重复循环任务(可持久化) - FreeScheduler
202 0
|
8月前
|
小程序 调度 数据库
jeecg-boot集成xxl-job调度平台,每秒/每分钟/手动都能执行成功,但是设置固定时间不触发?
jeecg-boot集成xxl-job调度平台,每秒/每分钟/手动都能执行成功,但是设置固定时间不触发?
|
2月前
|
存储 Java 调度
Sppring集成Quartz简单案例详解 包括(添加、停止、恢复、删除任务、获取下次执行时间等)
Sppring集成Quartz简单案例详解 包括(添加、停止、恢复、删除任务、获取下次执行时间等)
35 2
|
6月前
|
SQL 关系型数据库 MySQL
PolarDB产品使用问题之想要所有表执行是否需要时间分段执行
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
8月前
|
数据安全/隐私保护
如何自动(定时/间隔/重复)执行 同步文件、备份打包加密压缩文件
该文提供了一个工具的下载链接,分别在百度网盘和蓝奏云,提取码分别为&qwu2&quot;和&quot;2r1z&quot;。工具的使用需结合之前发布的两篇教程:《快捷自由定时重启、注销、关机》和《如何从多个文件夹内转移全部文件(忽略文件夹的结构)(进行复制)(再打包)》。操作步骤包括设定&quot;来源路径&quot;进行Zip打包,启用&quot;备份模式&quot;,然后保存批量复制任务,最后在定时器中执行已设置的批量文件复制任务。文中附有相关截图以供参考。
|
7月前
|
弹性计算 运维 Serverless
函数计算产品使用问题之如何自己设置定时任务
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
JSON 前端开发 关系型数据库
解决mysql 库中间时间查询出来是时间戳方法 【数据库查询出时间,传给前端变为时间戳】【可用】
解决mysql 库中间时间查询出来是时间戳方法 【数据库查询出时间,传给前端变为时间戳】【可用】
337 0
|
SQL 关系型数据库 MySQL
MySQL定时调用预置函数完成数据更新
MySQL定时调用预置函数完成数据更新
206 0
MySQL定时调用预置函数完成数据更新