hangfire笔记

program.cs中加入代码

//任务写入redis的配置
var HangfireConnectionString = ConfigurationHelper.GetSettings("Hangfire:ConnectionString");
var HangfireDb = ConfigurationHelper.GetSettings("Hangfire:Db");
//Attempts 为任务重试次数 OnAttemptsExceeded 为任务全部处理失败后将任务置为什么状态
GlobalJobFilters.Filters.Add(new AutomaticRetryAttribute { Attempts = 10, DelaysInSeconds = new[] { 1 } , OnAttemptsExceeded = AttemptsExceededAction.Fail});

builder.Services.AddHangfire(config => config.UseRedisStorage(HangfireConnectionString, new RedisStorageOptions
{
    Db = int.Parse(HangfireDb),
    //多久读取一次,最低15秒
    FetchTimeout = TimeSpan.FromSeconds(15)
}));

builder.Services.AddHangfireServer();

执行后台延时任务

    TimeSpan delay = TimeSpan.FromSeconds(10);
    //延时10秒执行任务
    var id = BackgroundJob.Schedule(() => RunTest(), delay);
    //任务执行完毕后取返回值处理逻辑
    BackgroundJob.ContinueJobWith(id, () => CheckResult(id));


    public void CheckResult(string jobId)
    {
        var result = JobStorage.Current.GetMonitoringApi().JobDetails(jobId);
        Console.WriteLine(result.Serialize());
    }

如果要用到失败重试机制,或使用递归,要在program里面注入自己这个类

    builder.Services.AddScoped<IPurchaseOrderBiz, PurchaseOrderBiz>();
   //从redis获取重试次数
   private async Task BackgroundJobTaskAsync(Push_Order_Data post)
   {
       var count = await FreeRedisManageData.GetRedisOrderRetryCountAsync(post.shop_platform, post.order_id, _serviceName);
       if (count != -1 && count < retryCount)
       {
           if (await FreeRedisManageData.SetRedisOrderRetryCountAsync(post.shop_platform, post.order_id, _serviceName, count + 1))
           {
               TimeSpan delay = TimeSpan.FromSeconds(delayMinutes);
               var jobid = BackgroundJob.Schedule(() => OrderServiceDeal(post), delay);
                //延时任务执行成功后执行的操作
               //BackgroundJob.ContinueJobWith(jobid, () => Application.GetProviderService<IPurchaseOrderBiz>().CheckResult(jobid));
               //Console.WriteLine($"{DateTime.Now.ToString("G")} 延时任务ID:{jobid}");
           }
       }
       else
       {
           await FreeRedisManageData.DelRedisOrderRetryCountAsync(post.shop_platform, post.order_id, _serviceName);
           Console.WriteLine($"{post.order_id} [自动采购任务]已达最大失败重试次数");
           //BackgroundJob.Delete(jobid)
       }
   }
/// <summary>
/// 判断任务返回的数据
/// </summary>
/// <param name="jobId"></param>
public void CheckResult(string jobId)
{
    //获取任务执行结果
    var jobResult = JobStorage.Current.GetMonitoringApi().JobDetails(jobId);
    var succeeded = jobResult?.History.FirstOrDefault(a=>a.StateName.EqualsStrings("Succeeded"));
    if (succeeded != null && succeeded.Data.TryGetValue("Result", out string result))
    {
        var apiResult = result.Deserialize<ApiResult>();
        if (apiResult != null && apiResult.code == (int)ReturnCode.Exception)
        {
            //自己我逻辑,是否重试
            var delay = TimeSpan.FromMinutes(delayMinutes);
            //可以不重新获取服务
            var jobid = BackgroundJob.Schedule(() => Application.GetProviderService<IPurchaseOrderBiz>().OrderServiceDeal(null), delay);
            BackgroundJob.ContinueJobWith(jobid, () => Application.GetProviderService<IPurchaseOrderBiz>().CheckResult(jobid));
        }
    }
}

asp.net core程序没有添加仪表盘配置将有可能报错:Current JobStorage instance has not been initialized yet

在program中加入


var app = builder.Build();
app.UseHangfireDashboard("/hangfire", new DashboardOptions
{
    ...
});

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hangfire 是一个用于 .NET 平台的开源后台作业管理框架,它允许您在 ASP.NET 应用程序中轻松执行后台作业,如发送电子邮件、生成报告、清理数据库等。 Hangfire 提供了一种简单、直观的方式来定义和执行后台作业。您可以使用 Hangfire 在后台执行方法、定时任务、队列任务等。它还提供了一个基于 WEB 的用户界面,以便您可以轻松地查看、管理和监控您的后台作业。 以下是 Hangfire 的一些主要特点: 1. 随时随地启动、停止或暂停后台任务。 2. 支持定时任务、延迟任务和队列任务。 3. 支持多种存储方式,如 SQL Server、PostgreSQL、Redis 等。 4. 提供了一个 WEB 界面,方便您查看后台任务的执行情况。 5. 支持分布式部署,允许多个应用程序使用同一个任务队列。 下面是一个简单的示例代码,演示了如何使用 Hangfire 在后台执行一个方法: ``` public class MyJob { public void DoJob() { // 执行后台任务 Console.WriteLine("Hello, Hangfire!"); } } // 在 Startup.cs 中配置 Hangfire public class Startup { public void Configuration(IAppBuilder app) { // 配置 Hangfire GlobalConfiguration.Configuration.UseSqlServerStorage("connectionString"); app.UseHangfireDashboard(); app.UseHangfireServer(); // 注册后台作业 var job = new MyJob(); BackgroundJob.Enqueue(() => job.DoJob()); } } ``` 在这个示例中,我们首先定义了一个名为 MyJob 的类,其中包含了一个名为 DoJob 的方法。然后,在 Startup.cs 中配置 Hangfire,指定了使用 SQL Server 存储后台任务,并启用了 Hangfire 的 Dashboard 和 Server。最后,我们使用 BackgroundJob.Enqueue 方法注册了一个后台任务,使其在启动应用程序后立即执行。 使用 Hangfire,您可以轻松地实现后台任务管理,并提高应用程序的可靠性和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值