开源软件
1、Hangfire
Hangfire是一个开源框架,它帮助您创建、处理和管理后台作业。
功能特征:
BackgroundJob.Enqueue(() => Console.WriteLine("Hello, world!"));
BackgroundJob.Schedule(() => Console.WriteLine("Hello, world!"), TimeSpan.FromMinutes(5));
RecurringJob.AddOrUpdate(() => Console.Write("Easy!"), Cron.Daily);
RecurringJob.AddOrUpdate(() => Console.Write("Powerful!"), "0 12 * */2");
SQL Server 与 Redis 持久化支持。Hangfire使用持久性存储来存储作业、队列和统计信息,并让它们在应用程序重启后继续存在。存储子系统的抽象程度足以支持经典的SQL Server和快速的Redis。
自动重试机制。如果你的方法遇到了一个暂时的异常,不用担心——它会在几秒钟内自动重试。如果所有重试尝试都已用尽,则可以从集成的web界面手动重新启动。还可以使用AutomaticRetryAttribute类控制重试行为。只需将其应用于您的方法,告诉Hangfire重试次数:
[AutomaticRetry(Attempts = 100)]
public static void GenerateStatistics() { }
BackgroundJob.Enqueue(() => GenerateStatistics());
保证执行任务。Hangfire是在知道托管环境可以杀死每行上的所有线程的情况下制作的。因此,它在成功完成之前不会删除作业,并且包含不同的隐式重试逻辑以在其处理中止时执行该作业。
实例方法调用。Hangfire除了支持静态方法调用,还支持调用实例方法。当worker看到给定的方法是实例方法时,它将首先激活它的类。默认情况下,使用Activator.CreateInstance方法,因此默认情况下仅支持具有默认构造函数的类。但是您可以插入IoC容器并通过构造函数传递依赖项。
public class EmailService
{
public void Send() { }
}
BackgroundJob.Enqueue<EmailService>(x => x.Send());
public void Method(IJobCancellationToken token)
{
for (var i = 0; i < Int32.MaxValue; i++)
{
token.ThrowIfCancellationRequested();
Thread.Sleep(1000);
}
}
app.UseHangfire(config =>
{
config.UseServer(100);
});
// or
var server = new BackgroundJobServer(100);
一些核心组件作为扩展:QueueAttribute、PreserveCultureAttribute、AutomaticRetryAttribute、SqlServerStorage、RedisStorage、NinjectJobActivator、AutofacJobActivator、ScheduledState。
官网:https://www.hangfire.io/
2、Quartz.NET
Quartz.NET是.NET平台下应用最早最广泛的老牌定时任务任务调度组件。它是一个功能齐全的开源作业调度系统,从小的应用程序到大型企业系统都可以使用。它可以与任何其他软件系统集成,也可以与任何其他软件系统一起使用。它提供了简单的操作,如调度/非调度作业、启动/停止/暂停调度程序等。
使用Quartz.NET可以定时轮询数据库同步、定时邮件通知、定时处理数据等。Quartz.NET允许开发人员根据时间间隔(或天)来调度作业。它实现了作业和触发器的多对多关系,还能把多个作业与不同的触发器关联。整合了 Quartz.NET的应用程序可以重用来自不同事件的作业,还可以为一个事件组合多个作业。
.NET Framework 通过 System.Timers.timer 类具有“内置”计时器功能。为什么有人会使用Quartz而不是这些标准功能? 原因包括以下几个方面:
对于一些简单的应用程序,这些功能可能并不重要,在这种情况下,不使用Quartz.NET可能是正确的决定。
官网:https://www.quartz-scheduler.net/
GitHub:https://github.com/quartznet/quartznet
3、ScheduleMaster
ScheduleMaster是一个开源的分布式任务调度系统,它基于.NET Core 3.1平台构建,支持跨平台多节点部署运行。
技术栈:
ASP.NET Core3.1、EntityFramework Core3.0、Mysql5.7、Quartz.Net、BeyondAdmin、Jquery...
Gitee:https://gitee.com/hey-hoho/ScheduleMasterCore
4、FluentScheduler
FluentSchedule 是.NET平台下的一款轻量级任务调度组件。接口丰富,功能强大,简单易容。官网提供的丰富示例,让开发者很容易上手。如果在项目中简单的设置定时任务,优先使用该组件。
官网:https://fluentscheduler.github.io/
GitHub:https://github.com/fluentscheduler/FluentScheduler
Timer是.NET内置的定时器类,它位于命名空间System.Timers
下。Timer是一个基于服务器端的计时器,提供了Interval
属性来设置重复触发定时任务的间隔(单位为毫秒),触发事件则由Elapsed
事件来指定。另外,还可以通过AutoReset
属性来设置Timer的Elapsed
事件只触发一次或者重复触发。
文档地址:https://docs.microsoft.com/en-us/dotnet/api/system.timers.timer?view=net-6.0
6、Coravel
Coravel 是一个接近零配置的 .NET Core 库,使任务调度、缓存、队列、邮件、事件广播(等等)变得轻而易举!
文档地址是:https://docs.coravel.net/
使用方法:
注册服务
先在 ConfigureServices 方法里,配置服务
services.AddScheduler();
//注册Coravel调用的任务,注意要注册成瞬时服务
services.AddTransient<CipAssistant.External.Jobs.UpdateTrendJob>();services.AddQueue();
一般注册以上 3 个服务,其中第二个需要引入自己定义好的计划动作;
然后在管道里注入服务
var provider = app.ApplicationServices;provider.UseScheduler(scheduler =>
{
scheduler.Schedule<CipAssistant.External.Jobs.UpdateTrendJob>()
.EveryThirtyMinutes()//30分钟更新一次
.Weekday(); 、
});
}
使用很简单,就这么几步就完成了。