.NET Core使用 Coravel 实现任务调度
前言
前段时间需要在一个新项目里添加两个后台任务,去定时请求两个供应商的API来同步数据;由于项目本身只是一个很小的服务,不太希望引入太重的框架,同时也没持久化要求;于是我开始寻找在Quartz.Net、Hangfire之外,是否还有更为轻量级的框架满足我的要求,最终我选择了Coravel.
简介
Coravel是一个专为.NET Core设计的.NET Standard库,除了任务调度,还提供了像队列、缓存、邮件等其它高级功能。特点就是对开发者十分友好,接入十分简单、优雅、流畅,接近于零配置。
作为一个生于2018年的年轻项目,后发优势明显,一开始就是基于.Net Standard 2.0实现,没有历史负担,同时又可以利用很多.Net Core新特性。
用法
首先安装Coravel包
dotnet add package coravel |
下面演示在.Net 6 Minimal API项目中接入Coravel并设置两个定时任务,是不是非常简单:)
using Coravel; | |
var builder = WebApplication.CreateBuilder(args); | |
//只使用Coravel的任务调度功能 | |
builder.Services.AddScheduler(); | |
//注册你自己的调度任务 | |
builder.Services.AddTransient<YourCoravelJob1>(); | |
builder.Services.AddTransient<YourCoravelJob2>(); | |
var app = builder.Build(); | |
//配置任务 | |
app.Services.UseScheduler(scheduler => | |
{ | |
scheduler.Schedule<YourCoravelJob1>().EveryFiveMinutes(); //每5分钟执行一次Job1 | |
scheduler.Schedule<YourCoravelJob2>().Hourly().Monday(); // 每周一每小时执行一次 | |
}); |
Coravel预先定义好了很多常用的间隔频率,非常的全面,像上面用到的 EveryFiveMinutes()
和 Hourly()
,是不是非常的简单优雅;当然Coravel也支持Cron表达式。
Invocable
是Coravel中的核心概念,代表一个独立的任务,上面的YourCoravelJob1和YourCoravelJob2就是 Invocable
,Coravel直接调度这些Invocable
。
要创建你自己的Invocable
,只需实现 IInvocable
接口,在 Invoke
方法中编码你的任务。
public class YourCoravelJob1 : IInvocable | |
{ | |
private readonly ILogger _logger; | |
public YourCoravelJob1(ILogger<YourCoravelJob1> logger) | |
{ | |
_logger = logger; | |
} | |
public async Task Invoke() | |
{ | |
_logger.LogInformation("start.."); | |
} | |
} | |
} |
原理
Coravel使用是的.Net Core 2.0引入的IHostedService来实现后台定时任务。(因此只有.Net Core 2.0以上的项目才能使用Coravel)
public interface IHostedService | |
{ | |
Task StartAsync(CancellationToken cancellationToken); | |
Task StopAsync(CancellationToken cancellationToken); | |
} |
SchedulerHost即实现了IHostedService接口,在 其StartAsync
方法中,当程序完全启动时,注册了一个的Timer
public Task StartAsync(CancellationToken cancellationToken) | |
{ | |
this._lifetime.ApplicationStarted.Register(InitializeAfterAppStarted); | |
return Task.CompletedTask; | |
} | |
private void InitializeAfterAppStarted() | |
{ | |
this._timer = new Timer(this.RunSchedulerPerSecondAsync, null, TimeSpan.Zero, TimeSpan.FromSeconds(1)); | |
} | |
private async void RunSchedulerPerSecondAsync(object state) | |
{ | |
if (this._schedulerEnabled) | |
{ | |
await this._scheduler.RunSchedulerAsync(); | |
} | |
} |
每秒调用 RunSchedulerAsync
激活到点的Invocable
,同时会根据情况将任务分组,在单独的线程分开执行。从这里可以看到Coravel是支持秒级任务的。
在 StopAsync
方法中,会先等待正在执行的任务完成才会关闭,这个功能还是比较重要。
public async Task StopAsync(CancellationToken cancellationToken) | |
{ | |
this._schedulerEnabled = false; // Prevents changing the timer from firing scheduled tasks. | |
this._timer?.Change(Timeout.Infinite, 0); | |
this._scheduler.CancelAllCancellableTasks(); | |
// If a previous scheduler execution is still running (due to some long-running scheduled task[s]) | |
// we don't want to shutdown while they are still running. | |
if (this._scheduler.IsRunning) | |
{ | |
this._logger.LogWarning(ScheduledTasksRunningMessage); | |
} | |
while (this._scheduler.IsRunning) | |
{ | |
await Task.Delay(50); | |
} | |
} | |
总结
本文介绍一个对开发者友好的、轻量级、零配置的.Net Standard库Coravel,并演示了如何使用Coravel在.Net 6 Minimal API中创建定时任务,最后浅析了的实现原理。作为一个年轻的框架,Coravel站在了巨人的肩膀上,相比Quartz.Net、Hangfire,也拥有很多亮点特性,很值得尝试。
任何问题或者建议,欢迎评论区留言讨论~
参考链接
.NET Core使用 Coravel 实现任务调度的更多相关文章
- .Net Core使用Coravel实现任务调度
前言 前段时间需要在一个新项目里添加两个后台任务,去定时请求两个供应商的API来同步数据:由于项目本身只是一个很小的服务,不太希望引入太重的框架,同时也没持久化要求:于是我开始寻找在Quartz.Ne ...
- Asp.Net Core下的开源任务调度平台ScheduleMaster—快速上手
概述 ScheduleMaster是一个开源的分布式任务调度系统,它基于Asp.Net Core平台构建,支持跨平台多节点部署运行. 它的项目主页在这里: https://github.com/hey ...
- .net core中使用Quartz任务调度
使用xml配置Quartz任务调度程序 1.Nuget Install-Package Quartz Install-Package Quartz.Plugins 2.站点根目录下加入文件quartz ...
- Asp.Net Core下的开源任务调度平台ScheduleMaster
从何说起 2017年初的时候,由于当时项目需要做了一个乞丐版定时调度系统,那时候只在单机上实现了核心的调度功能.做这个玩意之前也调研了社区中开源的解决方案,找了几个实地部署试跑了一下,其实都很不错.但 ...
- 【分享】Asp.net Core相关教程及开源项目
入门 全新的ASP.NET: https://www.cnblogs.com/Leo_wl/p/5654828.html 在IIS上部署你的ASP.NET Core项目: https://www.c ...
- Asp.net Core相关教程及开源项目推荐
入门 全新的ASP.NET: https://www.cnblogs.com/Leo_wl/p/5654828.html 在IIS上部署你的ASP.NET Core项目: https://www.c ...
- Uwl.Admin.Core开源框架(二) 使用QuartzNet
Uwl.Admin.Core中使用QuartzNet定时任务模块: 本文负责讲解RabbitMQ的使用 Uwl.Admin.Core使用的技术有: *.Async和Await 异步编程 *.Repos ...
- Asp.Net Core2.0 基于QuartzNet任务管理系统
Quartz.NET官网地址:https://www.quartz-scheduler.net/ Quartz.NET文档地址:https://www.quartz-scheduler.net/doc ...
- Net Core2.0 基于QuartzNet任务管理系统
Net Core2.0 基于QuartzNet任务管理系统 Quartz.NET官网地址:https://www.quartz-scheduler.net/ Quartz.NET文档地址:https: ...
- sonar:默认的扫描规则
https://blog.csdn.net/liumiaocn/article/details/83550309 https://note.youdao.com/ynoteshare1/index.h ...
随机推荐
- 关于vCenter6.7 导出的ovf 不能导入vCenter6.5/6.0的问题
正常从6.7导出ovf文件,包含四个文件. 编辑ovf文件,删除下面五条条目, 导入6.5时, 只用 ovf 和 vmdk 这两个文件导入 ,即可!
- Tomcat启动报A fatal error has been detected by the Java Runtime Environment
# # A fatal error has been detected by the Java Runtime Environment: # # SIGSEGV (0xb) at pc=0x0000 ...
- D - Pair of Topics
D - Pair of Topics 思路: 这个题需要一点思路,ai+aj>bi+bj可以转换成ai-bi+aj-bj>0,也就是c[i]=a[i]-b[i],只需要找c[i]+c[j] ...
- python_基础_习题集(10.25更新)
一.文件 1.利用文件充当数据库编写用户登录.注册功能 文件名称:userinfo.txt 基础要求: 用户注册功能>>>:文件内添加用户数据(用户名.密码等) 用户登录功能> ...
- skype网络异常无法登录
在有些win7电脑上安装最新版skype软件后,打开skype软件后显示无法访问网络 检查网络及防火墙,确定无异常 最后排查原因定位到操作系统的根证书 发现系统缺少部分DigiCert的根证书 从其他 ...
- dom-utils
function isNil(obj:any): boolean { return typeof obj === "undefined" || obj === null;}func ...
- 【文献阅读】An efficient motion planning based on grid map: Predicted Trajectory Approach with global path guiding
(1)主要工作内容 本文提出了一种基于轨迹预测法的欠驱动无人艇的全局运动规划算法.该方法考虑了无人艇的所有动力学约束,并且能找到一条根据船舶自身操纵系统进行跟踪的全局轨迹. 根据USV数学模型生成的预 ...
- nginx 日志分析之 access.log 格式详解
说明:access.log 的格式是可以自己自定义,输出的信息格式在nginx.conf中设置 一般默认配置如下: http { ... log_format main '$remote_addr - ...
- execsnoop
作用 execsnoop通过ftrace实时监控进程的exec()行为,输出短时进程的信息,包括进程 PID.父进程 PID.命令行参数以及执行的结果. 安装execsnoop git clone - ...
- Redis缓存中的数据和数据库不一致
首先关于两者数据的一致性包含有两种情况: (1)缓存中有数据时,那数据库中的数据要和缓存中的数据相同: (2)缓存中没有数据时,数据库中的数据必须是最新的. 如果不符合以上两种情况,就属于缓存和数据库 ...