ASP.NET Core Web API Hangfire

ASP.NET Core Web API Hangfire


前言

👨‍💻👨‍🌾📝记录学习成果,以便温故而知新

Hangfire是一种定任务调度器

本文使用MySQL服务器

本文也参考了其他人文章的一些思路。


一、安装

NuGet安装

Hangfire.AspNetCore

Hangfire.MySqlStorage

由于选择的MySQL数据库,所以安装Hangfire.MySqlStorage。

二、相关代码

Program.cs中添加代码:

1.代码片段

csharp 复制代码
builder.Services.AddHangfire(config =>
{
    config.SetDataCompatibilityLevel(CompatibilityLevel.Version_180)
          .UseSimpleAssemblyNameTypeSerializer()
          .UseRecommendedSerializerSettings();

    config.UseStorage(
              new MySqlStorage(
                  @"server=127.0.0.1;user=root;password=root;database=hangfiredb;allowuservariables=True;",
                  //必须允许用户自定义参数,不然面板不能使用
                  new MySqlStorageOptions { TablesPrefix = "Hangfire" })).UseHangfireHttpJob();
});

builder.Services.AddHangfireServer();
builder.Services.AddTransient<IBackgroundJobClient, BackgroundJobClient>();

MySQL数据连接:

@"server=127.0.0.1;user=root;password=root;database=hangfiredb;allowuservariables=True;"

如下:

.UseHangfireHttpJob()

实现的效果是可以在控制台添加任务调度。

前提是需要安装:

Hangfire.HttpJob

如下代码:

new MySqlStorageOptions { TablesPrefix = "Hangfire" }

是制定数据库中生成的表是以Hangfire开头,如下图:

在测试的时候没有处理好一个小细节,如果代码写成:

csharp 复制代码
new MySqlStorageOptions { TablesPrefix = "Hangfire_" }

将会更好!!!

2.代码片段

csharp 复制代码
app.UseHangfireDashboard();

3.运行效果

http://localhost:5279/hangfire/

三、测试代码

在项目新增控制器HangfireController及一个方法:

csharp 复制代码
[HttpGet("Execute")]
public void Execute(string job)
{
    Debug.WriteLine(job);
}

在控制台=>作业=>完成 中查看执行效果。

1.即发即弃作业

csharp 复制代码
[HttpGet("test1")]
public string Test1()
{
    string job = "即发即弃作业";
    BackgroundJob.Enqueue(() => Execute(job));
    return job;
}

测试效果:

2.延迟作业

csharp 复制代码
[HttpGet("test2")]
public string Test2()
{
    string job = "延迟作业";
    BackgroundJob.Schedule(() => Execute(job), TimeSpan.FromMinutes(1));
    return job;
}

测试效果:

3.重复作业

csharp 复制代码
[HttpGet("test3")]
public string Test3()
{
    string job = "重复作业";
    RecurringJob.AddOrUpdate(job, () => Execute(job), "0 * * * * ?", new RecurringJobOptions()
    {
        MisfireHandling = MisfireHandlingMode.Ignorable,
        TimeZone = TimeZoneInfo.Local,
    });
    return job;
}

4.延续作业

csharp 复制代码
[HttpGet("test4")]
public string Test4()
{
    var jobId = BackgroundJob.Enqueue(() => Execute("延续作业1"));
    BackgroundJob.ContinueJobWith(jobId, () => Execute("延续作业2"));
    return "延续作业";
}

测试效果:

5.页面调度作业

csharp 复制代码
[HttpGet("test5")]
public string Test5()
{
    Debug.WriteLine("页面调度作业:" + DateTime.Now.ToString());
    return "页面调度作业:" + DateTime.Now.ToString();
}


测试效果:

页面调度作业感觉像xxl-job,但是操作的便捷性上个人感觉略差一点意思。

相关推荐
.柒宇.18 小时前
AI掘金头条项目 Docker Compose 部署完整教程(附踩坑记录)
运维·后端·python·docker·容器·fastapi
Victor35619 小时前
MongoDB(118)如何在升级过程中进行数据备份?
后端
手握风云-19 小时前
Spring AI:让大模型住进 Spring 生态(三)
java·后端·spring
Victor35619 小时前
MongoDB(117)如何从旧版本迁移到新版本?
后端
pe7er1 天前
window管理开发环境篇 - 持续更新
前端·后端
陈随易1 天前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
陈随易1 天前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
大鱼七成饱1 天前
VMware NAT模式下固定内网IP(附详细图文)
后端
IT_陈寒1 天前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
兔子零10241 天前
手把手教你在 Claude Code 中接入 DeepSeek-V4
后端