Laravel 6.0 Schedule Preventing Task Overlaps 测试
1 目的
1.1 测试 Laravel 6.0 任务执行机制
2 意义
2.1 在日常开发中,有的任务比较复杂,在两次任务的调度周期间隔中无法完成。
2.2 为了防止重复任务的持续生成和反复调用,对服务器性能造成无谓消耗。
2.3 探索 $schedule->withoutOverlapping() 方法,如何阻断重复任务的调用
3 实验过程
3.1 不加 withoutOverlapping ()
3.1.1 Kernel
protected function schedule(Schedule $schedule)
{
// $schedule->command('inspire')
// ->hourly();
$schedule->job(new SyncAttach())
->everyMinute(); }
3.1.2 结果
[2019-10-10 10:59:02] local.INFO: SyncAttach f1951114-6e57-46aa-b037-2e8761c094a4 start
[2019-10-10 11:00:02] local.INFO: SyncAttach 087c5cb1-aaa9-4b3d-a69d-f2be196105ee start
[2019-10-10 11:01:02] local.INFO: SyncAttach f1951114-6e57-46aa-b037-2e8761c094a4 end
[2019-10-10 11:01:02] local.INFO: SyncAttach 6a80b5f2-39be-4676-91fd-5bd160a7afc0 start
3.1.3 分析
每一分钟都会生成一个 JOB,而不管上一个 JOB 是否完成。
3.2 加入 withoutOverlapping()
3.2.1 Kernel
protected function schedule(Schedule $schedule)
{
// $schedule->command('inspire')
// ->hourly();
$schedule->job(new SyncAttach())
->everyMinute()
->withoutOverlapping(); }
3.2.2 结果
[2019-10-10 11:05:02] local.INFO: SyncAttach d56a32c5-5ca1-47c8-8d96-81a397211276 start
[2019-10-10 11:07:02] local.INFO: SyncAttach d56a32c5-5ca1-47c8-8d96-81a397211276 end
[2019-10-10 11:07:02] local.INFO: SyncAttach 6d4480c1-9da5-48dd-abdb-46b315a19f2a start
[2019-10-10 11:09:02] local.INFO: SyncAttach 6d4480c1-9da5-48dd-abdb-46b315a19f2a end
3.2.3 分析
第6、8分钟并没有生成 Job,是因为上次的 Job 没有完成。
3.3 结论
3.3.1 加上 withoutOverlapping(),可以防止任务调用重复,只有旧的任务完成,新的任务才会产生
3.3.2 用 $schedule->call() 闭包方式执行任务,不可加入 withoutOverlapping(),报错:[2019-10-10 10:51:02] local.ERROR: A scheduled event name is required to prevent overlapping. Use the 'name' method before 'withoutOverlapping'.
Laravel 6.0 Schedule Preventing Task Overlaps 测试的更多相关文章
- Laravel 5.0 之命令及处理程序
本文译自 Matt Stauffer 的 系列文章 . 本文中涉及的新功能都是关于 Commands 的,这些特性在 Laravel 旧版本中已经有了,但是在 Laravel 5.0 中变得更加好用了 ...
- Red Gate系列之六 SQL Test 1.0.12.3 Edition SQL测试工具 完全破解+使用教程
原文:Red Gate系列之六 SQL Test 1.0.12.3 Edition SQL测试工具 完全破解+使用教程 Red Gate系列之六 SQL Test 1.0.12.3 Edition S ...
- 云优化的概念、Entity Framework 7.0、简单吞吐量压力测试
云优化的概念.Entity Framework 7.0.简单吞吐量压力测试 继续上一篇<开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)>之 ...
- redis3.0集群部署和测试
redis3.0集群部署和测试 环境介绍 两台Centos7的虚拟机模拟6个节点,A台3个master节点,B台3个slave节点A地址:172.16.81.140B地址:172.16.81.141r ...
- PHP laravel 5.0 Blade 模板引擎 Api使用备注
PHP laravel 5.0 Blade 模板引擎 Api使用备注 /** * PHP laravel 5.0 Blade 模板引擎 Api使用备注 **/ //子模版中开头,调用@extends( ...
- 测试开发:从0到1学习如何测试API网关
本文来自我的一名学员分享 日常工作中,难免会遇到临危受命的情况,虽然没有这么夸张,但是也可能会接到一个陌生的任务,也许只是对这个概念有所耳闻.也许这个时候会感到一丝的焦虑,生怕没法完成领导交给的测试任 ...
- Spring3.0.6定时任务task:scheduled
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- laravel 5.0 artisan 命令列表(中文简体)
#php artisan list Laravel Framework version Usage: [options] command [arguments] Options(选项): --help ...
- linux - native task api 测试
#include <stdio.h>#include <signal.h>#include <unistd.h>#include <sys/mman.h> ...
随机推荐
- 用selenium控制已打开的浏览器
在使用selenium进行自动化测试会遇到,手工打开浏览器,做了一部分操作后,并打开相关页面后再执行相关的自动化脚本. 如何使用selenium来接管先前已打开的浏览器呢?醍提出一个Google Ch ...
- PAT(B) 1053 住房空置率(Java)统计
题目链接:1053 住房空置率 (20 point(s)) 题目描述 在不打扰居民的前提下,统计住房空置率的一种方法是根据每户用电量的连续变化规律进行判断.判断方法如下: 在观察期内,若存在超过一半的 ...
- 在ubuntu 16.04 的vm中添加新网卡,同一网段不同ip
在ubuntu 16.04 的vm中添加新网卡,同一网段不同ip 来源 https://blog.51cto.com/744478/2083672 在ubuntu 16.04 的vm中新加了一块网卡, ...
- 简单web性能测试工具——ab命令(ApacheBench)
ab命令(ApacheBench) ----------转载内容 ApacheBench(即ab)通常用来做网站性能压力测试,是性能调优过程中必不可少的一环,ab命令会创建很多的并发访问线程,模拟多个 ...
- dede织梦如何去除网站底部的版权信息
dede织梦如何删除版权powered by?在织梦中,特别是在仿站之中,经常会在首页的底部出现powered by,这是dedecms织梦系统底部自带的官方链接power by等字样,很多新用户想去 ...
- 删除静态页面的html
function dellist(obj) { $(obj).parent().parent().remove(); }
- Bootstrap源码
1.Bootstrap Bootstrap是美国Twitter公司的设计师Mark Otto和Jacob Thornton合作基于HTML.CSS.JavaScript 开发的简洁.直观.强悍的前端开 ...
- 理解JVM之类加载机制
类完整的生命周期包括加载,验证,准备,解析,初始化,使用,卸载,七个阶段.其中验证,准备,解析统称为连接,类的卸载在前面的关于垃圾回收的博文中已经介绍. 加载,验证,准备,初始化,卸载这五个阶段的顺序 ...
- python程序打包exe
http://c.biancheng.net/view/2690.html 用inno setup做成安装包(官网上下载) http://www.jrsoftware.org/isdl.php
- HttpContext & HttpRuntime
问题引出 HttpContext.Current.Cache .VS. HttpRuntime.Cache HttpRuntime.Cache:获取当前应用程序的Cache HttpContext.C ...