如何在ASP.Net Core中使用 IHostedService的方法
在我们应用程序中常常会有一些执行后台任务和任务调度的需求,那如何在 asp.net core 中实现呢? 可以利用 azure webjobs 或者其他一些第三方任务调度框架,如:quartz 和 hangfire。
在 asp.net core 中,也可以将 后台任务 作为托管服务的模式,所谓的 托管服务 只需要实现框架中的 ihostedservice 接口并囊括进你需要的业务逻辑作为后台任务,这篇文章将会讨论如何在 asp.net core 中构建托管服务。
创建托管服务
要想创建托管服务,只需要实现 ihostedservice 接口即可,下面就是 ihostedservice 接口的声明。
这一节中我们在 asp.net core 中做一个极简版的 托管服务, 首先自定义一个 myfirsthostedservice 托管类,代码如下:
创建 backgroundservice
有一点要注意,上一节的 myfirsthostedservice 实现了 ihostedservice 接口,实际开发中并不需要这样做,因为 .net core 中已经提供了抽象类 backgroundservice,所以接下来重写抽象类的 executeasync 方法即可,如下代码所示:
下面的代码片段展示了一个简单的 log 方法,用于记录当前时间到文件中,这个方法由 托管服务 触发。
使用 executeasync 方法
接下来看看如何实现 executeasync 方法,这个方法的逻辑就是周期性(second/s)的调用 log() 方法,如下代码所示:
好了,下面是完整的 myfirsthostedservice 类代码,仅供参考。
托管服务注册
托管服务类已经写好了,要想注入到 asp.net core 中,需要在 startup.configureservices 中将 托管服务类 注入到 servicecollection 中,如下代码所示:
当把应用程序跑起来后,你会看见程序每秒都会往 d:\log.txt 文件中记录日志。
在 ihostedservice 中提供的 startasync 和 stopasync 可用于在 asp.net core 中执行或停止后台任务,你可以用它在你的应用程序中更新数据或其他操作,还有这些周期性业务逻辑是跑在后台线程中的,这样就不会导致主请求线程的阻塞。
译文链接:
到此这篇关于如何在asp.net core中使用 ihostedservice的方法的文章就介绍到这了,更多相关asp.net core使用 ihostedservice内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: C# 基于消息发布订阅模型的示例(下)
下一篇: C# 基于消息发布订阅模型的示例(上)
推荐阅读
-
使用NLog给Asp.Net Core做请求监控的方法
-
如何在Asp.Net Core MVC中处理null值的实现
-
asp.net core 使用 TestServer 来做集成测试的方法
-
ASP.NET Core中调整HTTP请求大小的几种方法
-
CSRF在ASP.NET Core中的处理方法详解
-
CSRF在ASP.NET Core中的处理方法详解
-
ASP.NET Core 2.1 使用Docker运行的方法步骤
-
在ASP.NET Core中创建内部使用Scoped服务的Quartz.NET宿主服务
-
ASP.NET 中使用 Routing 进行 URL 优化,规则中的 .html 不起作用的解决方法
-
使用HTTP-REPL工具测试ASP.NET Core 2.2中的WEB API项目