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,但是操作的便捷性上个人感觉略差一点意思。

相关推荐
程序员爱钓鱼1 小时前
Go语言实战案例-判断一个数是否为质数
后端·google·go
程序员爱钓鱼1 小时前
Go语言实战案例-读取本地文本文件内容
后端·google·go
斯是 陋室9 小时前
在CentOS7.9服务器上安装.NET 8.0 SDK
运维·服务器·开发语言·c++·c#·云计算·.net
mCell9 小时前
Go 并发编程基础:从 Goroutine 到 Worker Pool 实践
后端·性能优化·go
Python智慧行囊10 小时前
Flask 框架(一):核心特性与基础配置
后端·python·flask
inwith11 小时前
C#语法基础总结(超级全面)(二)
开发语言·c#
ん贤11 小时前
如何加快golang编译速度
后端·golang·go
摸鱼仙人~13 小时前
Spring Boot 参数校验:@Valid 与 @Validated
java·spring boot·后端
思无邪667513 小时前
从零构建搜索引擎 build demo search engine from scratch
后端
Littlewith13 小时前
Node.js:创建第一个应用
服务器·开发语言·后端·学习·node.js