Hangfire .NET任务调度框架实例

1、介绍

Hangfire是一个开源的.NET任务调度框架,提供了内置集成化的控制台(后台任务调度面板),可以直观明了的查看作业调度情况。

2、Nuget安装

3、编写代码

1)测试服务:FirstStartService

cs 复制代码
using Microsoft.Extensions.Hosting;
namespace HangfireTest.Service
{
    public class FirstStartService: IHostedService
    {
        public async Task StartAsync(CancellationToken cancellationToken)
        {
            await Task.Run(() =>
            {
                Console.WriteLine("FirstStartService......StartAsync");
            }, cancellationToken);
            //hangfire定时任务
            var id = Hangfire.BackgroundJob.Enqueue(() => Console.WriteLine("插入队列的任务"));
            Hangfire.BackgroundJob.Schedule(() => Console.WriteLine("延迟的任务"), TimeSpan.FromSeconds(5));
            Hangfire.RecurringJob.AddOrUpdate(() => Console.WriteLine("循环执行的任务"), Hangfire.Cron.Minutely);
            Hangfire.BackgroundJob.ContinueJobWith(id, () => Console.WriteLine("指定任务执行之后执行的任务"));
        }
        public async Task StopAsync(CancellationToken cancellationToken)
        {
            await Task.Run(() =>
            {
                Console.WriteLine("FirstStartService......StopAsync");
            }, cancellationToken);
        }
    }
}

2) 测试服务:SecondStartService

cs 复制代码
using Microsoft.Extensions.Hosting;
namespace HangfireTest.Service
{
    public class SecondStartService: IHostedService
    {
        public async Task StartAsync(CancellationToken cancellationToken)
        {
            await Task.Run(() =>
            {
                Console.WriteLine("SecondStartService......StartAsync");
            }, cancellationToken);
        }
        public async Task StopAsync(CancellationToken cancellationToken)
        {
            await Task.Run(() =>
            {
                Console.WriteLine("SecondStartService......StopAsync");
            }, cancellationToken);
        }
    }
}

3)Startup.cs注入测试服务和Hangfire(此实例项目为VS2022 .NET6所建的ASP.NET Core Web API测试项目 Program.cs和其他版本建的项目有所区别,但注入方式没区别)

cs 复制代码
/// <summary>
/// 应用程序的入口点和生命周期 -- 应用程序启动起处理的任务
/// </summary>
builder.Services.AddHostedService<FirstStartService>();
builder.Services.AddHostedService<SecondStartService>();

/// <summary>
/// Hangfire定时任务
/// </summary>
builder.Services.AddHangfire(x => x.UseSqlServerStorage("Data Source=localhost;Initial Catalog=Test;Integrated Security=True;")); // SqlServer
builder.Services.AddHangfireServer();

/// <summary>
/// Hangfire定时任务
/// </summary>
app.UseHangfireDashboard();

4、访问方式

访问调度控制面板:

本地访问方式:https://localhost:端口号/hangfire/

5、效果图

6、相关链接

① Hangfire官网

② Hangfire中文文档

③ Hangfire Github源码

一个简单的实例,如有帮助,欢迎点赞关注收藏!

相关推荐
唐青枫1 小时前
循环插入太慢?试试 C#.NET SqlBulkCopy,一次导入上百万数据
c#·.net
景早8 小时前
vue 记事本案例详解
前端·javascript·vue.js
乔冠宇10 小时前
vue需要学习的点
前端·vue.js·学习
老华带你飞11 小时前
商城推荐系统|基于SprinBoot+vue的商城推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·商城推荐系统
一 乐11 小时前
物业管理系统|小区物业管理|基于SprinBoot+vue的小区物业管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
H_HX12611 小时前
vue3 - 图片放大镜效果实现
前端·vue.js·vue3·vueuse·图片放大镜
sky-stars13 小时前
.NET 泛型编程(泛型类、泛型方法、泛型接口、泛型委托、泛型约束)
c#·.net·.netcore
梵得儿SHI15 小时前
Vue 模板语法深度解析:从文本插值到 HTML 渲染的核心逻辑
前端·vue.js·html·模板语法·文本插值·v-text指令·v-html指令
listhi52016 小时前
Vue.js 3的组合式API
android·vue.js·flutter
WYiQIU16 小时前
高级Web前端开发工程师2025年面试题总结及参考答案【含刷题资源库】
前端·vue.js·面试·职场和发展·前端框架·reactjs·飞书