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 分钟前
一个静默吞数据的时间戳陷阱
后端
李少兄19 分钟前
从原理到实战:Spring IoC/DI 核心知识体系与高频面试题全解
java·后端·spring
ServBay22 分钟前
ServBay 1.30.0 更新:双平台引入 MCP 服务,AI 编程助手成为全栈本地运维
后端·ai编程
张不才43 分钟前
分页查出来的数据总少几条?可能是 MyBatis 后置过滤的坑
后端
Windeal44 分钟前
Agent ToolCall 循环怎么定制?PI Extension 与 DeepAgents Middleware 两条岔路深度对比
后端·openai
鱼人1 小时前
targets 包实战:R 语言数据分析流水线自动化管理方案
后端
时雨__1 小时前
一文搞懂 Python 并发:GIL、多线程/多进程/协程怎么选
后端
Anson4321 小时前
Dubbo架构深度分析
后端
站大爷IP1 小时前
global和nonlocal到底有什么区别?
后端
二月龙1 小时前
从零开发 Shiny 交互式数据看板:本地运行到网页上线完整路径
后端