CronScheduler.AspNetCore

2025-12-07 0 590

CronScheduler.AspNetCore

注意:预释放软件包是通过feedz.io分发的。

概括

在.NET核心应用程序中解锁简化CRON调度的功能

您是否厌倦了复杂的调度库使您无法构建可扩展和高效的应用程序?别再看!引入Cronscheduler ,这是专门为.NET Core IHostIWebHost设计的轻便且易于使用的库。

Cronscheduler是基于亲吻原则的,是石英调度程序及其替代方案的简化替代方案。使用Cronscheduler,您可以轻松地使用CRON语法安排任务,并在任何.NET Core Generichost IHost中进行操作,从而使设置和配置变得轻而易举。

但这不是全部!我们还介绍了Istartupjob ,可以在主机准备启动之前对关键过程的异步初始化。这意味着您即使在复杂的kubernetes环境中,您的应用程序也可以正确初始化并顺利运行。

好处:

  • 轻巧且易于使用的库
  • cron语法简化调度
  • 在.NET Core Generichost IHostIWebHost中运行
  • 与ISTARTUPJOB对关键过程的异步初始化支持

立即加入Cronscheduler社区,并开始简化应用程序的调度需求!

请参阅迁移指南以进行升级。

给星星!

如果您愿意或正在使用此项目学习或启动解决方案,请给它一颗星。谢谢!

安装

  • 安装AspNetCore托管.NET CLI的软件包
    dotnet add package CronScheduler.AspNetCore
  • IHost托管.NET CLI安装软件包
    dotnet add package CronScheduler.Extensions

使用crontab格式进行工作/任务时间表

该图书馆最多支持Crontab格式的5秒钟工作间隔,感谢Hangfireio/Cronos库。

您可以使用https://cront*ab*-*generator.org/来生成所需的工作/任务时间表。

cron格式

cron表达是定义固定时间,日期和间隔的掩码。面具包括第二(可选),分钟,小时,每月和每天的每日田野。所有字段都允许您指定多个值,如果所有字段都包含匹配值,则任何给定的日期/时间都将满足指定的CRON表达式。

                                       Allowed values    Allowed special characters   Comment

┌───────────── second (optional)       0-59              * , - /                      
│ ┌───────────── minute                0-59              * , - /                      
│ │ ┌───────────── hour                0-23              * , - /                      
│ │ │ ┌───────────── day of month      1-31              * , - / L W ?                
│ │ │ │ ┌───────────── month           1-12 or JAN-DEC   * , - /                      
│ │ │ │ │ ┌───────────── day of week   0-6  or SUN-SAT   * , - / # L ?                Both 0 and 7 means SUN
│ │ │ │ │ │
* * * * * *

演示应用

  • cronschedulerworker-此示例演示了如何使用新的Microsoft .NET核心工人模板使用CronScheduler
  • cronschedulerapp-此示例演示了如何将CronScheduler与Aspnetcore应用程序使用。

可以在调度程序作业中注册选项和作业有两种方法。

  1. 基本和最有效的注册方法是通过IConfiguration

此作业注册假设作业名称的名称是相同的。

    services . AddScheduler ( ctx =>
    {
        ctx . AddJob < TestJob > ( ) ;
    } ) ;
  1. 相同Cron工作的复杂工厂注册,具有不同的选择
        services . AddScheduler ( ctx =>
        {
            var jobName1 = \"TestJob1\" ;

            ctx . AddJob (
                sp =>
                {
                    var options = sp . GetRequiredService < IOptionsMonitor < SchedulerOptions > > ( ) . Get ( jobName1 ) ;
                    return new TestJobDup ( options , mockLoggerTestJob . Object ) ;
                } ,
                options =>
                {
                    options . CronSchedule = \"*/5 * * * * *\" ;
                    options . RunImmediately = true ;
                } ,
                jobName : jobName1 ) ;

            var jobName2 = \"TestJob2\" ;

            ctx . AddJob (
                sp =>
                {
                    var options = sp . GetRequiredService < IOptionsMonitor < SchedulerOptions > > ( ) . Get ( jobName2 ) ;
                    return new TestJobDup ( options , mockLoggerTestJob . Object ) ;
                } , options =>
                {
                    options . CronSchedule = \"*/5 * * * * *\" ;
                    options . RunImmediately = true ;
                } ,
                jobName : jobName2 ) ;
        } ) ; 

Singleton计划工作及其依赖项的示例代码

    public class TorahQuoteJob : IScheduledJob
    {
        private readonly TorahQuoteJobOptions _options ;
        private readonly TorahVerses _torahVerses ;
        private readonly TorahService _service ;

        /// <summary>
        /// Initializes a new instance of the <see cref=\"TorahQuoteJob\"/> class.
        /// </summary>
        /// <param name=\"options\"></param>
        /// <param name=\"service\"></param>
        /// <param name=\"torahVerses\"></param>
        public TorahQuoteJob (
            IOptionsMonitor < TorahQuoteJobOptions > options ,
            TorahService service ,
            TorahVerses torahVerses )
        {
            _options = options . Get ( Name ) ;
            _service = service ?? throw new ArgumentNullException ( nameof ( service ) ) ;
            _torahVerses = torahVerses ?? throw new ArgumentNullException ( nameof ( torahVerses ) ) ;
        }

        // job name and options name must match.
        public string Name { get ; } = nameof ( TorahQuoteJob ) ;

        public async Task ExecuteAsync ( CancellationToken cancellationToken )
        {
            var index = new Random ( ) . Next ( _options . Verses . Length ) ;
            var exp = _options . Verses [ index ] ;

            _torahVerses . Current = await _service . GetVersesAsync ( exp , cancellationToken ) ;
        }
    }

然后在Program.cs中注册此服务。CS:

 var builder = WebApplication . CreateBuilder ( args ) ;

// Add services to the container.
builder . Services . AddScheduler ( builder =>
{
    builder . Services . AddSingleton < TorahVerses > ( ) ;
    builder . Services
        . AddHttpClient < TorahService > ( )
        . AddTransientHttpErrorPolicy ( p => p . RetryAsync ( ) ) ;

    builder . AddJob < TorahQuoteJob , TorahQuoteJobOptions > ( ) ;
    builder . Services . AddScoped < UserService > ( ) ;
    builder . AddJob < UserJob , UserJobOptions > ( ) ;

    builder . AddUnobservedTaskExceptionHandler ( sp =>
    {
        var logger = sp . GetRequiredService < ILoggerFactory > ( ) . CreateLogger ( \"CronJobs\" ) ;
        return ( sender , args ) =>
        {
            logger ? . LogError ( args . Exception ? . Message ) ;
            args . SetObserved ( ) ;
        } ;
    } ) ;
} ) ;

builder . Services . AddBackgroundQueuedService ( applicationOnStopWaitForTasksToComplete : true ) ;
builder . Services . AddDatabaseDeveloperPageExceptionFilter ( ) ;

builder . Services . AddStartupJob < SeedDatabaseStartupJob > ( ) ;
builder . Services . AddStartupJob < TestStartupJob > ( ) ;

builder . Logging . AddConsole ( ) ;
builder . Logging . AddDebug ( ) ;
builder . Logging . AddConfiguration ( builder . Configuration . GetSection ( \"Logging\" ) ) ;

var app = builder . Build ( ) ;

// Configure the HTTP request pipeline.
if ( app . Environment . IsDevelopment ( ) )
{
    app . UseDeveloperExceptionPage ( ) ;
    app . UseMigrationsEndPoint ( ) ;
}
else
{
    app . UseExceptionHandler ( \"/Home/Error\" ) ;
    app . UseHsts ( ) ;
}

app . UseHttpsRedirection ( ) ;
app . UseStaticFiles ( ) ;
app . UseCookiePolicy ( ) ;
app . UseAuthentication ( ) ;
app . UseRouting ( ) ;

app . MapControllers ( ) ;
app . MapDefaultControllerRoute ( ) ;
app . MapRazorPages ( ) ;

await app . RunStartupJobsAsync ( ) ;
await app . RunAsync ( ) ; 

在申请IStartupJobs之前

有许多情况下,用于使用IWebHost接口或IGenericHost启动Jobs。最常见的情况是确保创建和更新数据库。该库通过简单地进行以下操作使其成为可能:

  • Program.cs文件中添加以下内容:
 var builder = WebApplication . CreateBuilder ( args ) ;

// Add services to the container.
builder . Services . AddStartupJob < SeedDatabaseStartupJob > ( ) ;
builder . Services . AddStartupJob < TestStartupJob > ( ) ;

var app = builder . Build ( ) ;

// Configure the HTTP request pipeline.
await app . RunStartupJobsAsync ( ) ;
await app . RunAsync ( ) ; 

背景队列

在应用程序的某些情况下,需要排队任务。为了Startup.cs此添加以下内容。

    services . AddBackgroundQueuedService ( ) ;

然后添加示例异步任务以由排队的托管服务执行。

    public class MyService
    {
        private readonly IBackgroundTaskQueue _taskQueue ;

        public MyService ( IBackgroundTaskQueue taskQueue )
        {
            _taskQueue = taskQueue ;
        }

        public void RunTask ( )
        {
            _taskQueue . QueueBackgroundWorkItem ( async ( token ) =>
            {
                // run some task
                await Task . Delay ( TimeSpan . FromSeconds ( 10 ) , token ) ;
            } } ) ;
        }
    } 

执照

麻省理工学院许可证

下载源码

通过命令行克隆项目:

git clone https://github.com/kdcllc/CronScheduler.AspNetCore.git

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

申明:本文由第三方发布,内容仅代表作者观点,与本网站无关。对本文以及其中全部或者部分内容的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。本网发布或转载文章出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,也不代表本网对其真实性负责。

左子网 开发教程 CronScheduler.AspNetCore https://www.zuozi.net/31869.html

api library
下一篇: api library
常见问题
  • 1、自动:拍下后,点击(下载)链接即可下载;2、手动:拍下后,联系卖家发放即可或者联系官方找开发者发货。
查看详情
  • 1、源码默认交易周期:手动发货商品为1-3天,并且用户付款金额将会进入平台担保直到交易完成或者3-7天即可发放,如遇纠纷无限期延长收款金额直至纠纷解决或者退款!;
查看详情
  • 1、描述:源码描述(含标题)与实际源码不一致的(例:货不对板); 2、演示:有演示站时,与实际源码小于95%一致的(但描述中有”不保证完全一样、有变化的可能性”类似显著声明的除外); 3、发货:不发货可无理由退款; 4、安装:免费提供安装服务的源码但卖家不履行的; 5、收费:价格虚标,额外收取其他费用的(但描述中有显著声明或双方交易前有商定的除外); 6、其他:如质量方面的硬性常规问题BUG等。 注:经核实符合上述任一,均支持退款,但卖家予以积极解决问题则除外。
查看详情
  • 1、左子会对双方交易的过程及交易商品的快照进行永久存档,以确保交易的真实、有效、安全! 2、左子无法对如“永久包更新”、“永久技术支持”等类似交易之后的商家承诺做担保,请买家自行鉴别; 3、在源码同时有网站演示与图片演示,且站演与图演不一致时,默认按图演作为纠纷评判依据(特别声明或有商定除外); 4、在没有”无任何正当退款依据”的前提下,商品写有”一旦售出,概不支持退款”等类似的声明,视为无效声明; 5、在未拍下前,双方在QQ上所商定的交易内容,亦可成为纠纷评判依据(商定与描述冲突时,商定为准); 6、因聊天记录可作为纠纷评判依据,故双方联系时,只与对方在左子上所留的QQ、手机号沟通,以防对方不承认自我承诺。 7、虽然交易产生纠纷的几率很小,但一定要保留如聊天记录、手机短信等这样的重要信息,以防产生纠纷时便于左子介入快速处理。
查看详情

相关文章

猜你喜欢
发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务