广告
返回顶部
首页 > 资讯 > 后端开发 > ASP.NET >.net任务调度框架Hangfire简介
  • 805
分享到

.net任务调度框架Hangfire简介

2024-04-02 19:04:59 805人浏览 薄情痞子
摘要

任务调度是我们项目中常见的功能,虽然任务调度的功能实现本身并不难,但一个好用的轮子还是可以给我们的开发的效率提升不少的。 在.net环境中,较为有名的任务调度框架是HangFire与

任务调度是我们项目中常见的功能,虽然任务调度的功能实现本身并不难,但一个好用的轮子还是可以给我们的开发的效率提升不少的。

.net环境中,较为有名的任务调度框架是HangFire与Quartz.NET,本文这里主要介绍Hangfire,相比Quartz.NET来说,它提供了更加友好的页面,使用起来更加方便。Hangfire的优点网上有不少文章介绍的,这里简单的列举一下:

  • 支持各种常见的任务类型
  • 持久化保存任务、队列、统计信息
  • 重试机制
  • 多语言支持
  • 支持任务取消
  • 支持按指定Job Queue处理任务
  • 服务器端工作线程可控,即job执行并发数控制
  • 分布式部署,支持高可用
  • 良好的扩展性,如支持ioc、Hangfire Dashboard授权控制、ASP.net core、持久化存储等

简单使用:

这里就简单的演示.net core下基本的用法。首先建立一个.Net CoreWEB项目,如果没有别的需求使用空项目模板也可以。

1. 添加程序包:

Install-Package Hangfire

2.配置数据库

Hangfire默认支持sqlserver和Redis,也可以通过第三方扩展支持sqlite等数据库。这里我选择的是常用的sqlserver。

使用sqlserver作为存储引擎时,首先需要在sqlserver上创建一个数据库,可以不用建表,Hangfire会自动建表。

3. 注册服务:

首先在Startup.cs的ConfigureServices 方法中注册服务:

services.AddHangfire(r => r.UseSqlServerStorage("Data Source=192.168.18.130;Initial Catalog=HangfireDemo;User ID=sa;PassWord=abc123@ss"));

然后在Configure 方法中加入HangfireServer及HangfireDashboard:

app.UseHangfireServer();
app.UseHangfireDashboard();

此时启动程序,就可以通过Http://localhost:5000/hangfire查看程序主界面了,默认还自带中文

4. 配置任务

Hangfire提供了一系列接口配置任务:

//基于队列的任务处理(Fire-and-forget jobs)
var jobId = BackgroundJob.Enqueue(
    () => Console.WriteLine("Fire-and-forget!"));


//延迟任务执行(Delayed jobs)
var jobId = BackgroundJob.Schedule(
    () => Console.WriteLine("Delayed!"),
    TimeSpan.FromDays(7));


//定时任务执行(Recurring jobs)
RecurringJob.AddOrUpdate(
    () => Console.WriteLine("Recurring!"),
    Cron.Daily);


//延续性任务执行(Continuations)
RecurringJob.AddOrUpdate(
    () => Console.WriteLine("Recurring!"),
    Cron.Daily);

这些任务是配置在服务器上的,如果要动态配置任务则可以通过让服务器提供接口即可。

缺点

最后也简单的说下Hangfire的缺点吧,另一个比较热门的任务调度框架是Quartz.net,它和Hangfire相比有如下优点:

  • 支持秒级单位的定时任务处理,但是Hangfire只能支持分钟及以上的定时任务处理
  • 更加复杂的触发器,日历以及任务调度处理
  • 可配置的定时任务

其中Hangfire最大的缺点可能是第一条,任务执行时间精度不够,不过在大部分应用场景来说,这个不是很大的问题。

到此这篇关于.net任务调度框架Hangfire的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: .net任务调度框架Hangfire简介

本文链接: https://www.lsjlt.com/news/153268.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • .net任务调度框架Hangfire简介
    任务调度是我们项目中常见的功能,虽然任务调度的功能实现本身并不难,但一个好用的轮子还是可以给我们的开发的效率提升不少的。 在.net环境中,较为有名的任务调度框架是HangFire与...
    99+
    2022-11-13
  • .net任务调度框架FluentScheduler简介
    之前我在文章中介绍过.net中的任务调度框架Hangfire,HangFire虽然本身输入比较简单好用的,但是,如果我们的程序本身提供的服务不是任务调度,而任务调度只是里面并不重要的...
    99+
    2022-11-13
  • .net任务调度框架Hangfire怎么使用
    这篇文章主要讲解了“.net任务调度框架Hangfire怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“.net任务调度框架Hangfire怎么使用”吧!简单使用:这里就简单的演示.n...
    99+
    2023-07-02
  • Abp集成HangFire开源.NET任务调度框架
    目录简要说明什么是Hangfire简要说明 后台作业在系统开发的过程当中,是比较常用的功能。因为总是有一些长耗时的任务,而这些任务我们不是立即响应的,例如 Excel 文档导入、批量...
    99+
    2022-11-13
  • .net任务调度框架FluentScheduler怎么使用
    这篇文章主要介绍“.net任务调度框架FluentScheduler怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“.net任务调度框架FluentScheduler怎么使用”文章能帮助大家解...
    99+
    2023-07-02
  • Java 任务调度框架 Quartz实操
    目录1、Quartz 1.1 引入依赖 1.2 入门案例 任务类,需要实现 Job 接口 定时器类 1.3 Job 与 JobDetail 1.4 JobExecutionConte...
    99+
    2022-11-12
  • golang任务调度框架怎么使用
    在Go语言中,可以使用多种任务调度框架来进行任务的管理和调度,例如:1. Gin: Gin是一个高性能的Go语言Web框架,它支持路...
    99+
    2023-09-13
    golang
  • java任务调度框架怎么使用
    Java任务调度框架通常用于在指定的时间间隔或特定时间点执行任务。常见的Java任务调度框架有Quartz和Spring Task。...
    99+
    2023-09-13
    java
  • Python 强大的任务调度框架 Celery!
    什么是 celery这次我们来介绍一下 Python 的一个第三方模块 celery,那么 celery 是什么呢? celery 是一个灵活且可靠的,处理大量消息的分布式系统,可以在多个节点之间处理某个任务; celery 是一个专注于实...
    99+
    2023-05-14
    Python 框架 Celery
  • python任务调度框架怎么使用
    Python任务调度框架最常用的是APScheduler,下面是APScheduler的使用步骤:1. 安装APScheduler:...
    99+
    2023-09-21
    python
  • 任务调度框架Quartz怎么使用
    要使用Quartz任务调度框架,您可以按照下面的步骤进行操作:1. 引入Quartz依赖:您可以在项目的构建文件中引入Quartz的...
    99+
    2023-09-21
    Quartz
  • golang任务调度框架怎么实现
    要实现一个Golang任务调度框架,可以按照以下步骤进行: 定义任务结构体:首先,定义一个任务结构体,包含任务的属性,例如任务的I...
    99+
    2023-10-25
    golang
  • Java任务调度框架Quartz怎么使用
    本篇内容介绍了“Java任务调度框架Quartz怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! Quartz相较于Time...
    99+
    2023-06-22
  • Python强大的任务调度框架Celery怎么使用
    本篇内容介绍了“Python强大的任务调度框架Celery怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是 celery这次我们...
    99+
    2023-07-06
  • web分布式定时任务调度框架怎么使用
    这篇文章主要讲解了“web分布式定时任务调度框架怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“web分布式定时任务调度框架怎么使用”吧!一、业务背景1.1 为什么需要使用定时任务调度...
    99+
    2023-06-04
  • Java的任务调度框架cron4j 2.2.5发布的示例分析
    Java的任务调度框架cron4j 2.2.5发布的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。cron4j 2.2.5 发布了,主要改进有:Predictor ...
    99+
    2023-06-17
  • 用 Python 和 Javascript 实现分布式任务调度,有哪些值得推荐的框架?
    随着云计算和大数据的发展,分布式系统的重要性越来越受到关注。在分布式系统中,任务调度是一个非常关键的部分,而分布式任务调度可以更好地利用资源,提高系统的效率和可靠性。本文将介绍用 Python 和 Javascript 实现分布式任务调度的...
    99+
    2023-06-19
    leetcode javascript 分布式
  • 如何在Python中实现一个分布式计算框架,以及任务调度和结果收集的机制和策略
    标题:Python中的分布式计算框架实现及任务调度与结果收集机制摘要:分布式计算是一个有效利用多台计算机资源来加速任务处理的方法。本文将介绍如何使用Python实现一个简单的分布式计算框架,包括任务调度和结果收集的机制与策略,并提供相关代码...
    99+
    2023-10-22
    分布式计算 任务调度 结果收集
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作