zoukankan      html  css  js  c++  java
  • 基于 dotnet standard 2.0 的定时任务组件 Light.Cron

    Light.Cron是一个使用简单的基于dotnet standard 2.0的定时任务组件, 通过执行对象和对执行方法的Attribute进行定时任务配置

    nuget 安装

    PM> Install-Package Light.Cron

    使用配置

    [CrontabJob]
    public class CrontabObject
    {
        [CrontabSchedule("crontab1", "* * * * *")]
        public void DoSomeThing()
        {
            // Todo
        }
    }

    执行对象需要标记CrontabJobAttribute, 执行方法需要标记CrontabScheduleAttribute

    CrontabScheduleAttribute

    属性说明
    Name 指定Crontab方法的唯一名称
    Schedule 调度计划, 如* * * * *
    AllowConcurrentExecution 允许并发执行, 如上一次执行还没结束, 下一次执行时间已到, 允许同时执行
    RunImmediately 启用时不判断Schedule是否符合, 马上执行
    AutoEnable CrontabService启动时自动启用

    系统会通过使用依赖注入方式生成一个SingletonCrontabService对象进行定时任务调度.

    通过使用IServiceCollection.AddCrontabJob依赖注入配置, 再使用IApplicationBuilder.UseCrontabJob启动CrontabService.

    public class Startup
        {
            public Startup(IConfiguration configuration)
            {
                Configuration = configuration;
            }
    
            public IConfiguration Configuration { get; }
    
            public void ConfigureServices(IServiceCollection services)
            {
                services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
                services.AddCrontabJob();
            }
    
            public void Configure(IApplicationBuilder app, IHostingEnvironment env)
            {
                app.UseCrontabJob();
                app.UseMvc();
            }
        }

    CrontabService默认会扫描EntryAssembly程序集中的有CrontabJobAttribute的类以及该类中有CrontabScheduleAttribute的方法, 如要扫描其他程序集, 可以在AddCrontabJob中可以使用CrontabOptionsBuilder进行配置

    属性/方法说明
    ScanAllAssembly 扫描所有程序集
    SetAssembly 扫描指定的程序集

    调度命令格式

    Light.Cron完全兼容Linux Crontab时间格式, 如下

    *  *  *  *  *
    分 时 日 月 周

    第1列表示分钟0~59 第2列表示小时0~23 第3列表示日期1~31 新增e标记作为月末最后一天 第4列表示月份1~12 第5列标识号星期0~7(0和7表示星期天)

    每天早上6点 
    0 6 * * *
    
    每天10点至16点 
    0 10-16 * * *
    
    每隔两个小时 
    0 */2 * * *
    
    每月1日,15日和最后1日的早上5点
    0 5 1,15,e * * 

    跨时间段

    当时间段格式出现结束时间小于开始时间, 则代表由开始时间到下一级时间的开始时间, 如

    每月1号22点到2号4点之间的时间段
    * 22-4 1 * * 
    每周一至周五晚上22点到次日4点之间的时间段, 里面包含周六的0点-4点, 不包含周一的0点-4点
    * 22-4 * * 1-5

    月末日期

    日期格式中增加新增e标记作为月末最后一天, 并且可以通过e+数字代表最后一天再往前倒数天数, 如当月共31天, 则e=31, e1=30, e2=29, e3=28. 当月共30天, 则e=30, e1=29, e2=28, e3=27. 该语法同样支持范围

    0 0 e3-e1 * * 

    时间范围

    Light.Cron可以通过新语法HH:mm-HH:mm将时分结合, 替换原有的时分设置, 如

    每日9点30分至15点0分, 每隔一分钟执行一次
    09:30-15:00 * * *
    每日21点30分至次日的5点30分, 每隔5分钟执行一次
    21:30-05:30/5 * * *

    多组调度计划

    Light.Cron可以通过|符号支持多组调度计划, 如

    0点至11点, 每分钟执行一次, 12点至23点, 每5分钟执行一次
    * 0-11 * * *|*/5 12-23 * * *

    简略写法

    如下一级及其以之后的时间范围都是*, 可以简略不写, 如

    * * * * * = *
    30 9 * * * = 30 9
    09:30-15:00 * * * = 09:30-15:00
    0 0 1 * * = 0 0 1
    0 0 1 2-5 * = 0 0 1 2-5

    源码下载:https://github.com/ZhengHengWU/light-cron-Core

  • 相关阅读:
    5.6Java 创建File
    5.6Java File ApI
    Java字符集乱码
    5.17Java文件的拷贝
    5.10Java实操IO流,面向接口编程,面向父类编程
    5.6Java File对象使用递归打印子孙级目录以及文件的名称
    5.10JavaIo流四大抽象类
    5.17Java文件字节流
    5.7通过Maven配置seleeniumjava依赖
    5.6Java多态的介绍
  • 原文地址:https://www.cnblogs.com/ZhengHengWU/p/12579658.html
Copyright © 2011-2022 走看看