.NET 中的 Worker Service 入门介绍

翻译自 Steve Gordon 2020年3月30日的文章 《WHAT ARE .NET WORKER SERVICES?》 [1]

随着 .NET Core 3.0 的发布,ASP.NET 团队引入了一个新的 Worker Service 项目模板,该模板作为 .NET SDK 的一部分发布。在本文中,我将向您介绍这个新模板,以及使用它开发的一些实际的服务示例。

译者注:
请先完成以下准备工作,以便于您理解本文。
1、下载并安装最新的 .NET SDK:https://dotnet.microsoft.com/download
2、命令行运行 dotnet new Worker -n "MyService" 命令,创建一个 Worker Service 项目。

什么是 .NET Core Worker Service?

Worker Service 是使用模板构建的 .NET 项目,该模板提供了一些有用的功能,可以将常规控制台应用程序变得更加强大。Worker Service 运行于宿主(Host)的概念之上,宿主维护应用程序的生命周期。宿主还提供了一些常见的特性,如依赖注入、日志记录和配置。

Worker Service 通常是长时间运行的服务,执行一些规律发生的工作负载。

§Worker Service 的一些例子

  • 处理来自队列、服务总线或事件流的消息、事件

  • 响应对象、文件存储中的文件更改

  • 聚合数据存储中的数据

  • 丰富数据提取管道中的数据

  • AI/ML 数据集的格式化和清理

还可以开发一个这样的 Worker Service,该服务从头到尾执行一个过程,然后关闭。结合调度程序,便可以支持定期的批处理工作负载。例如,调度程序每隔一小时启动一次服务,完成一些汇总数据的计算,然后关闭。

Worker Service 没有用户界面,也不支持直接的用户交互,它们特别适用于设计微服务架构。在微服务体系结构中,职责通常被划分为不同的、可单独部署的、可伸缩的服务。随着微服务架构的成长和发展,拥有大量的 Worker Service 会变得越来越常见。

Worker Service 模板提供了什么?

完全可以在不使用 Worker Service 模板的情况下开发长时间运行的 Worker Service。在 .NET Core 的早期版本中我是这样做的,使用依赖注入容器手动建立宿主,然后启动我的处理工作负载。

在默认情况下,Worker Service 模板包含了有用的基础组件,比如依赖注入,这样我们就可以集中精力在其上构建业务逻辑。它包含了一个管理应用程序生命周期的宿主。

Worker Service 模板本身是相当基础的,它只包含了三个开箱即用的核心文件。

§1. Program.cs

第一个是 Program 类。该类包含 .NET 控制台应用程序所必需的 Main 方法入口点,.NET 运行时期望在启动 .NET 应用程序时在 Program 类中查找此方法。

public class Program
{public static void Main(string[] args){CreateHostBuilder(args).Build().Run();}public static IHostBuilder CreateHostBuilder(string[] args) =>Host.CreateDefaultBuilder(args).ConfigureServices((hostContext, services) =>{services.AddHostedService<Worker>();});
}

在 Program 类中,作为 Worker Service 模板一部分的是 CreateHostBuilder 方法,该方法创建一个 IHostBuilderIHostBuilder 接口定义了一个类型,该类型使用生成器模式生成 IHost 的实例。此模板通过调用 Host 类中的静态 CreateDefaultBuilder 方法来创建一个新的 HostBuilder

然后,它使用生成器来配置 IHost,该 IHost 被用于运行 Worker Service 应用程序。宿主提供了依赖注入容器和日志记录等功能,就像我们可以在 ASP.NET Core 应用程序中使用的那样。事实上,从 .NET Core 3.0 开始,ASP.NET Core Web 应用程序和 .NET Core Worker Service 都运行在同一 IHost 上的。

默认情况下,它包含了一个服务注册,稍后我会在本文中介绍,暂时不用担心。

从 Main 方法中调用 CreateDefaultBuilder 方法,将构建并立即运行宿主。当 .NET 运行时调用 Main 方法时,应用程序启动,宿主将保持运行,监听标准的关闭信号(例如按下 CTRL+C 键)。

§2. appsettings.json

如果您以前使用过 ASP.NET Core,将会非常熟悉 appsettings.json 文件,它是应用程序配置的常见来源之一。宿主被设计为,当启动应用程序时,使用任意已注册的配置提供程序从多个来源加载应用程序配置。其中一种提供程序是从 appsettings.json 加载配置,该文件内容由 JSON 组成,其结构包含表示应用程序配置的键和值。这些值可以随意地定义在对相关配置按逻辑分组成的片段(Sections)内。

在 Worker Service 中,启动时会检查相同的配置源(包括此 appsettings.json 文件和环境变量),并从不同的源构建最终的配置。默认情况下会加载多种默认的提供程序,因此也会加载多种源。如果需要,您也可以自定义宿主用来加载配置数据的提供程序。

{"Logging": {"LogLevel": {"Default": "Information","Microsoft": "Warning","Microsoft.Hosting.Lifetime": "Information"}}
}

模板中的默认 appsettings 文件中包含日志记录库的配置设置项,默认对 Worker Service 可用。这里的配置是为某些日志记录上下文设置记录级别的。

§3. Worker.cs

Worker 是一个您在默认的 ASP.NET Core 项目模板中见不到的新类。它是托管服务与宿主相结合的魔力所在,提供了 Worker Service 的基础。

让我们来看一下它的代码:

public class Worker : BackgroundService
{private readonly ILogger<Worker> _logger;public Worker(ILogger<Worker> logger){_logger = logger;}protected override async Task ExecuteAsync(CancellationToken stoppingToken){while (!stoppingToken.IsCancellationRequested){_logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now);await Task.Delay(1000, stoppingToken);}}
}

此类从 BackgroundService 抽象基类派生。BackgroundService 类实现了一个名为 IHostedService 的接口。

BackgroundService 包含一个名为 ExecuteAsync 的抽象方法,我们必须在子类中重写该方法,就像 Worker Service 模板中提供的 Worker 类中所做的那样。ExecuteAsync 方法返回一个 Task,在 BackgroundService 内部,期望此 Task 是一些长时间运行的工作负载。该 Task 会被启动并在后台运行。

在内部,宿主将启动 IHostedService 的所有注册实现(包括从 BackgroundService 抽象类派生的类型)。请记住,BackgroundService 为我们实现了 IHostedService

§4. 如何注册托管服务(IHostedService)?

下一个显而易见的问题是,如何注册 IHostedService ?如果我们返回到 Program.cs 的代码,我们将会找到答案:

public static IHostBuilder CreateHostBuilder(string[] args) =>Host.CreateDefaultBuilder(args).ConfigureServices((hostContext, services) =>{services.AddHostedService<Worker>();});

在 ConfigureServices 方法中,可以向依赖注入容器注册类型。AddHostedService 是为 IServiceCollection 定义的一个扩展方法,它允许我们注册一个实现了 IHostedService 的类。

该模板中已将 Worker 类注册为托管服务。

在启动时,宿主将找到已注册的 IHostedService 的所有实例,并按顺序启动它们,此时,它们的长时间运行的工作负载会作为后台任务来运行。

为什么要构建 .NET Core Worker Service?

简单的答案是——何时以及是否需要它们!如果您需要开发一个微服务,它没有用户界面,并执行长时间运行的工作,那么 Worker Service 很可能是一个好的选择。

请记住,Worker Service 的底层只是一个控制台应用程序。该控制台应用程序使用宿主将应用程序转换为运行的服务,直到收到停止的信号。宿主带来了您可能已经熟悉的一些特性,比如依赖关系注入。使用和 ASP.NET Core 中可用的相同的日志记录和配置扩展,使得开发可记录日志信息且需要一些配置的 Worker Service 变得相当轻松。当构建运行在云上的 Worker Service 时,几乎总会存在这种需求。例如,您可能需要为与您的 Worker Service 相交互的任何外部服务提供配置(比如一个队列 URL)。

Worker Service 可用于从现有的 ASP.NET Core 应用程序提取职责,设计新的基于 .NET Core 的微服务。

总结

在本文中,我介绍了 Worker Service 项目模板,以及它的一些潜在用例。我们探索了使用 Worker Service 模板创建的新项目中所包含的三个默认文件。

§Worker Service 模板包含哪些文件?

  • Program.cs:控制台应用程序的入口点,创建并运行宿主以管理应用程序生命周期并生成一个长期运行的服务。

  • appsettings.json:一个提供应用程序配置值的 JSON 文件。

  • Worker.cs:派生自 BackgroundService 基类,用于定义作为后台任务执行的长时间运行的工作负载。

§Worker Service 是什么?

  • 不需要用户交互的应用程序。

  • 使用宿主来维护控制台应用程序的生命周期,直到宿主收到关闭的信号。将控制台应用程序转换为长时间运行的服务。

  • 包含和 ASP.NET Core 相同的功能,如依赖注入、日志记录和配置。

  • 执行定期和长时间运行的工作负载。


相关链接:

  1. https://www.stevejgordon.co.uk/what-are-dotnet-worker-services WHAT ARE .NET WORKER SERVICES? ↩︎

作者 :Steve Gordon
译者 :技术译民
出品 :技术译站(https://ITTranslator.cn/)

END

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/302623.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

为什么前后端分离了,你比从前更痛苦?

你有没有遇到过&#xff1a;前端代码刚写完&#xff0c;后端的接口又变了。接口文档永远都是不对的。测试工作永远只能临近上线才能开始。为什么前后端分离了&#xff0c;你比从前更痛苦&#xff1f;前后端分离早已经不是新闻&#xff0c;当真正分离之后确遇到了更多问题。要想…

响应式设计(Response Web Design)浅谈

响应式Web设计&#xff0c;这个话题可能是当下Web设计领域里讨论和应用比较多的话题了&#xff0c;为什么要响应式Web设计?什么是响应式Web设计? Web发展迅速&#xff0c;各种应用和服务层出不穷&#xff0c;现在打开电脑&#xff0c;可能使用最多的程序应该是浏览器了&#…

现在6岁的小朋友都开始学编程了……

前段时间&#xff0c;朋友跟小木说&#xff1a;现在的小孩什么都要学&#xff0c;以后是不是都要学编程了&#xff1f;小木鄙夷地笑了一下&#xff1a;他们已经学编程了啊&#xff01;朋友表情↓↓↓朋友&#xff1a;纳尼&#xff1f;&#xff1f;&#xff1f;我到大学才接触编…

记一次 .NET 医院CIS系统 内存溢出分析

一&#xff1a;背景 1. 讲故事前几天有位朋友加wx求助说他的程序最近总是出现内存溢出&#xff0c;很崩溃&#xff0c;如下图&#xff1a;和这位朋友聊下来&#xff0c;发现他也是搞医疗的&#xff0c;哈哈&#xff0c;.NET 在医疗方面还是很有市场的????????????&…

丘成桐:完全不懂数学,才会有“数学无用”的说法

全世界有3.14 % 的人已经关注了数据与算法之美▲中国科学院院长白春礼&#xff08;右&#xff09;与数学家丘成桐&#xff08;左&#xff09;为晨兴数学金奖获得者李思&#xff08;中&#xff09;颁奖培养第一流的学生&#xff0c;首先要有对于学问的兴趣&#xff0c;而非奔着考…

动手实现一个适用于.NET Core 的诊断工具

前言大家可能对诊断工具并不陌生&#xff0c;从大名鼎鼎的 dotTrace&#xff0c;到 .NET CLI 推出的一系列的高效诊断组件&#xff08;dotnet trace,dotnet sos,dotnet dump&#xff09;等, 这些工具提升了对程序Debug的能力和效率&#xff0c;可以让开发人员从更高层次的维度来…

android 强制下线功能,Android学习之基础知识八—Android广播机制实践(实现强制下线功能)...

强制下线功能算是比较常见的了&#xff0c;很多的应用程序都具备这个功能&#xff0c;比如你的QQ号在别处登录了&#xff0c;就会将你强制挤下线。实现强制下线功能的思路比较简单&#xff0c;只需要在界面上弹出一个对话框&#xff0c;让用户无法进行任何操作&#xff0c;必须…

USB权限的设置

USB设备给我们日常生活中带了很多的方便&#xff0c;能够在不同的不同的移动设备中传递数据。但也给我们的数据安全带来了隐患&#xff0c;它可以拷贝走我们计算机中很机密的信息&#xff01;通过下面的操作后&#xff0c;将使我们有用的信息增加更大安全性&#xff0c;至小也能…

漫谈高数——泰勒级数的物理意义

全世界有3.14 % 的人已经关注了数据与算法之美高等数学干吗要研宄级数问题&#xff1f;是为了把简单的问题弄复杂来表明自己的高深&#xff1f; No,是为了把各种简单的问题/复杂的问题&#xff0c;他们的求解过程用一种通用的方法来表示。提一个问题&#xff0c;99*99等于多少&…

保持学习,从这几个公众号开始!

全世界有3.14 % 的人已经关注了数据与算法之美关注了几百个公众号无目的的看文章却如鸡肋一般食之无味弃之可惜你是否也觉得时间被浪费&#xff1f;生命被辜负了&#xff1f;点击关注下面几个公众号它们每天更新有态度、有温度的原创文字每一篇推文都值得你点开长按二维码&…

回顾 | 在 GitHub 上贡献到开源项目

点击蓝字关注我们精彩回顾GitHub 是世界上最大的开源社区&#xff0c;拥有数百万个开源项目。GitHub 的优势之一是在项目上进行协作非常容易。在本研讨会中&#xff0c;我们将介绍在 GitHub 上找到开源项目并为其做出贡献的难易程度。我们将向您展示如何创建拉取请求&#xff0…

html assign无效,Object.assign的一些用法

Object.assign的一些用法2020/11/12 20:19:03  字体&#xff1a;大 中 小 浏览 1289 我要评论需要定制网站程序、公众号程序、微信小程序可以联系&#xff1a;565449214或者加微信13961347334(备注&#xff1a;需要技术)或者在处理一些技术问题时&#xff0c;有什么不懂的地…

R语言和 Python —— 一个错误的分裂

全世界有3.14 % 的人已经关注了数据与算法之美最近有一些文章提出与年龄相关的问题&#xff1a;“崭露头角的年轻数据科学家们是学习R语言还是Python更好?”答案似乎都是“视情况而定”&#xff0c;在现实中没有必要在R和Python中做出选择&#xff0c;因为你两个都用得到。推荐…

快速修改HTML5,HTML5无刷新修改URL(示例代码)

HTML5新添加了两个api分别是pushState和replaceState&#xff0c;DOM中的window对象通过window.history方法提供了对浏览器历史记录的读取&#xff0c;可以在用户的访问记录中前进和后退&#xff0c;我们可以开始操作这个历史记录堆栈。实例一、通过pushState修改URL通过这句代…

这一平台只要把握住风口期,自己就能当老板!

我是电商珠珠 短视频渐渐走进大家的视野&#xff0c;改变了大家的日常娱乐方式。从19年开始&#xff0c;抖音开始发展电商平台-抖音小店。 在改变大家娱乐方式的同时&#xff0c;还将直播电商的热度掀了起来&#xff0c;由此改变了大家的购物方式&#xff0c;给大家带来了方便…

如何用TensorFlow实现人工智能?

自 2015 年 11 月 9 号发布之后&#xff0c;TensorFlow 逐渐成为人工智能领域最广泛运用的深度学习框架。那么TensorFlow框架到底是什么&#xff1f;TensorFlow 是一个大规模机器学习的开源框架&#xff0c;提供了多种深度神经网络的支持。不仅 Google 在自己的产品线使用 Tens…

一不小心,知乎炸了!

阅读本文大概需要7分钟。昨天晚上加完班发完原创文章&#xff1a;如何成为一个搞垮公司的程序员&#xff1f;就准备回家了&#xff0c;突然发现知乎一堆咨询消息&#xff0c;看了看原来是之前回答的一个问题突然火了&#xff0c;就是这个&#xff1a;好家伙&#xff0c;一天不到…

[转载]Android Layout标签之-viewStub,requestFocus,merge,include

定义Android Layout(XML)时&#xff0c;有四个比较特别的标签是非常重要的&#xff0c;其中有三个是与资源复用有关&#xff0c;分别是<viewStub/>, <requestFocus />, <merge /> and<include />。可是以往我们所接触的案例或者官方文档的例子都没有着…

查询2021抚顺高考成绩,2021年抚顺高考状元是谁分数多少分,历年抚顺高考状元名单...

2020年抚顺一年一度的高考考试已经结束&#xff0c;今年抚顺高考状元是谁呢&#xff0c;抚顺高考状元出自哪个高中学校&#xff0c;文理科分数是多少分&#xff0c;一起来了解。一、2020年抚顺高考状元名单资料2020年抚顺高考状元名单和学校相关信息&#xff0c;截至目前发文时…

Android菜单详解——理解android中的Menu

前言 今天看了pro android 3中menu这一章&#xff0c;对Android的整个menu体系有了进一步的了解&#xff0c;故整理下笔记与大家分享。 PS&#xff1a;强烈推荐《Pro Android 3》&#xff0c;是我至今为止看到的最好的一本android书&#xff0c;中文版出到《精通Android 2》。 …