快速开始¶

安装¶

在nuget上有关于Hangfire的 一系列软件包 。 要使用 SQL Server 存储将Hangfire安装到 ASP.NET 应用程序 中,请在Package Manager Console窗口中键入以下命令:

  1. PM> Install-Package Hangfire

配置¶

安装软件包后,在OWIN启动类添加或更新如以下几行:

  1. using Hangfire;
  2.  
  3. // ...
  4.  
  5. public void Configuration(IAppBuilder app)
  6. {
  7. GlobalConfiguration.Configuration.UseSqlServerStorage("<connection string or its name>");
  8.  
  9. app.UseHangfireDashboard();
  10. app.UseHangfireServer();
  11. }

请配置授权

默认情况下,只有本地访问权限才能使用Hangfire仪表盘。为了远程访问必须配置 仪表盘授权

然后打开Hangfire仪表盘来测试您的配置。请构建项目并在浏览器中打开以下URL:

http://<your-site>/hangfire
快速开始 - 图1

用法¶

新增一个任务…¶

Hangfire处理不同类型的后台作业, 并且每个任务都在单独的执行上下文中被调用。

Fire-and-forget¶

这是主要的后台作业类型,在持久化的消息队列中处理。一旦你创建一个 fire-and-forget 任务, 它将被加入到队列 (默认为”default”,除此之外也支持多个队列)中。 该队列将被指定的消费者监听并执行。

  1. BackgroundJob.Enqueue(() => Console.WriteLine("Fire-and-forget"));

Delayed¶

如果要延迟某种类型的方法调用,请调用以下方法。在指定的延迟时间之后,工作将被放置到队列中,作为常规的 fire-and-forget 类型的任务处理。

  1. BackgroundJob.Schedule(() => Console.WriteLine("Delayed"), TimeSpan.FromDays(1));

Recurring¶

要按照周期性(小时,每天等)调用方法,请使用 RecurringJob 类调用。您可以使用 CRON 表达式 来处理更复杂的使用场景。

  1. RecurringJob.AddOrUpdate(() => Console.WriteLine("Daily Job"), Cron.Daily);

Continuations¶

Continuations 允许您通过将多个后台作业结合起来定义复杂的工作流。

  1. var id = BackgroundJob.Enqueue(() => Console.WriteLine("Hello, "));
  2. BackgroundJob.ContinueWith(id, () => Console.WriteLine("world!"));

… 请放心¶

Hangfire将您的工作保存到持久存储中,并以可靠的方式处理它们。这意味着在您中止Hangfire工作线程,卸载应用程序域,甚至终止进程, 你的任务仍会保存起来等待处理 . Hangfire在你执行完任务的代码之前都标记状态,包括可能失败的任务状态。它包含不同的自动重试功能,存储错误的信息。

这对于通用托管环境(如IIS Server)非常重要。可以通过 特定的、超时、错误处理的策略 终止进程来避免错误发生。如果您没有使用可靠的处理和自动重试,您的任务可能会丢失。 这样,你的客户因此等不到 email, 被告和通知 等等。

但是当您的存储空间破损时,Hangfire无法做任何事情。请为您的存储使用不同的故障切换策略,以保证在发生灾难时处理每个作业。

原文:

http://hangfirezh.zhs.press/quick-start.html