Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
      • 什么是 Hangfire?
      • 安装和配置 Hangfire
      • 在应用程序中使用 Hangfire
        • 定义后台任务
        • 调度后台任务
        • 延迟后台任务
        • 定时后台任务
        • 监控任务状态和历史记录
      • 总结
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 任务调度
一个大西瓜
2023-04-18
目录

Hangfire

开源地址

Github:https://github.com/HangfireIO/Hangfire (opens new window)

在 .NET 开发中,我们经常需要执行一些较为耗时的任务,例如发送邮件、生成报表等。这些任务可能需要花费较长的时间,并且可能会导致用户体验变差。为了避免这种情况,我们可以使用 Hangfire 这个库来进行后台任务调度,从而提高应用程序的性能和用户体验。

# 什么是 Hangfire?

Hangfire 是一个 .NET 库,用于管理后台任务。它提供了一种简单的方法来执行长时间运行的任务,例如发送电子邮件,生成报表,处理消息队列等。与其他后台任务调度库不同的是,Hangfire 提供了一个可靠的机制,可以在任务失败时自动重试,以确保任务始终被执行。Hangfire 还提供了一个简单的 Web 界面,可以查看任务状态、执行历史和性能指标。

Hangfire 的主要优点包括:

  • 简单易用。Hangfire 提供了一个简单的 API,让您可以快速地定义和执行后台任务。
  • 可靠性高。Hangfire 提供了一种可靠的机制,可以在任务失败时自动重试,以确保任务始终被执行。
  • 灵活性高。Hangfire 可以与多种存储后端集成,包括 SQL Server,Redis,MongoDB 等,可以满足不同应用程序的需求。

# 安装和配置 Hangfire

要使用 Hangfire,您需要先安装 Hangfire NuGet 包。可以使用 NuGet 管理器或 Package Manager Console 安装该包。例如,在 Visual Studio 中,可以通过以下命令安装 Hangfire:


Install-Package Hangfire

安装完成后,您需要配置 Hangfire,以便它可以连接到您选择的存储后端。Hangfire 支持多种存储后端,包括 SQL Server,Redis,MongoDB 等。您可以根据自己的需求选择合适的存储后端。在本文中,我们将使用 SQL Server 作为存储后端。

要配置 Hangfire 连接到 SQL Server,您需要先安装 Hangfire.SqlServer NuGet 包。可以使用 NuGet 管理器或 Package Manager Console 安装该包。例如,在 Visual Studio 中,可以通过以下命令安装 Hangfire.SqlServer:


Install-Package Hangfire.SqlServer

安装完成后,您需要在应用程序的 Startup.cs 文件中配置 Hangfire。以下是一个示例配置:


public void ConfigureServices(IServiceCollection services)
{
    // 添加 Hangfire 服务
    services.AddHangfire(config =>
    {
        // 配置 Hangfire 使用 SQL Server 作为存储后端
        config.UseSqlServerStorage(Configuration.GetConnectionString("Hangfire"));
    });
}

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    // 启用 Hangfire 仪表盘
    app.UseHangfireDashboard();

    // 启用 Hangfire 服务
    app.UseHangfireServer();
    ```
}

在这个示例中,我们首先在 ConfigureServices 方法中添加了 Hangfire 服务,并配置了 Hangfire 使用 SQL Server 作为存储后端。接下来,在 Configure 方法中,我们启用了 Hangfire 仪表盘和 Hangfire 服务。这样,我们就完成了 Hangfire 的基本配置。

# 在应用程序中使用 Hangfire

现在,我们已经完成了 Hangfire 的配置,接下来我们将看看如何在应用程序中使用 Hangfire。

# 定义后台任务

在使用 Hangfire 执行后台任务之前,我们需要定义任务。Hangfire 支持多种任务类型,包括方法调用、委托、Lambda 表达式、反射调用等。以下是一个示例任务定义:

public class BackgroundJobService
{
    public void SendEmail(string emailAddress, string subject, string body)
    {
        // 发送电子邮件
    }
}

在这个示例中,我们定义了一个名为 SendEmail 的方法,该方法接受三个参数:emailAddress、subject 和 body。我们将在后面的示例中使用此方法。

# 调度后台任务

一旦我们定义了任务,就可以使用 Hangfire 调度任务了。以下是一个示例代码:


BackgroundJob.Enqueue<BackgroundJobService>(x => x.SendEmail("test@example.com", "Subject", "Body"));

在这个示例中,我们使用 BackgroundJob.Enqueue 方法来调度 SendEmail 方法。此方法将在后台执行,并且可以在 Hangfire 仪表板中查看其状态和历史记录。

# 延迟后台任务

除了立即执行后台任务外,Hangfire 还支持延迟执行任务。例如,您可以在指定的时间后执行任务,或者在指定的时间间隔后重复执行任务。以下是一个示例代码:


BackgroundJob.Schedule<BackgroundJobService>(x => x.SendEmail("test@example.com", "Subject", "Body"), TimeSpan.FromSeconds(60));

在这个示例中,我们使用 BackgroundJob.Schedule 方法来延迟执行 SendEmail 方法。此方法将在 60 秒后执行。

# 定时后台任务

除了延迟执行任务外,Hangfire 还支持定时执行任务。例如,您可以在每天的特定时间执行任务,或者在指定的时间间隔后重复执行任务。以下是一个示例代码:


RecurringJob.AddOrUpdate<BackgroundJobService>("SendEmail", x => x.SendEmail("test@example.com", "Subject", "Body"), Cron.Daily);

在这个示例中,我们使用 RecurringJob.AddOrUpdate 方法来定时执行 SendEmail 方法。此方法将在每天的特定时间执行。

# 监控任务状态和历史记录

Hangfire 提供了一个 Web 仪表板,用于监控任务状态和历史记录。您可以在应用程序中启用仪表板,并访问 /hangfire 路径来查看仪表板。以下是一个示例配置:


public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    app.UseHangfireDashboard();
    app.UseHangfireServer();
}

在这个示例中,我们启用了 Hangfire 仪表板,并将其配置为应用程序的根路径。

在 Hangfire 仪表板中,您可以查看任务状态和历史记录。您还可以取消任务、删除任务和查看任务详情。

# 总结

Hangfire 是一个可靠的后台任务调度库,用于执行长时间运行的任务,例如发送电子邮件、生成报表、处理消息队列等。与其他后台任务调度库不同的是,Hangfire 提供了一种可靠的机制,可以在任务失败时自动重试,以确保任务始终被执行。Hangfire 还提供了一个简单的 Web 界面,可以查看任务状态、执行历史和性能指标。

在本文中,我们介绍了如何安装和配置 Hangfire,并提供了一些示例代码来说明如何在应用程序中使用 Hangfire。我们还介绍了如何使用 Hangfire 仪表板来监控任务状态和历史记录。

如果您需要执行长时间运行的任务,例如发送电子邮件、生成报表、处理消息队列等,我建议您考虑使用 Hangfire。Hangfire 可以帮助您提高应用程序的性能和用户体验,并确保您的任务始终被执行。

上次更新: 2023/04/26, 22:10:06
SqlSugar
Quartz

← SqlSugar Quartz→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式