.NET Core 3.1和WorkerServices构建Windows服务

爱谁谁
发布: 2025-09-11 09:19:01
原创
730人浏览过

asp.net core 3引入了worker service这一有趣功能。作为一个asp.net core模板,它允许开发者创建托管长期运行的后台服务。这些服务通过实现ihostedservice接口来定义后台任务逻辑,被称为“托管服务”。它们可以部署在windows服务以及linux守护程序中。

我们可以通过命令行界面的dotnet new命令来创建一个名为customWorker的WorkerService应用。以下是创建命令:

dotnet new worker -o customWorker
登录后复制

Program.cs文件如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace WorkerServiceDemo
{
    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>();
                });
    }
}
登录后复制

Worker类实现了BackgroundService,这是IHostedService的基类。通过调用ExecuteAsync(CancellationToken)方法来运行后台服务。ExecuteAsync方法返回一个Task,代表后台服务的整个生命周期。在ExecuteAsync方法执行(例如通过await)之前,不会启动其他服务。应避免在ExecuteAsync中进行长时间的阻塞初始化。在StopAsync(CancellationToken)方法中,主机会等待ExecuteAsync完成。

当调用IHostedService.StopAsync时,会触发取消令牌。当取消令牌被激发以便正常关闭服务时,ExecuteAsync的实现应立即完成。否则,服务将在关闭超时后不正常关闭。

Worker类的实现如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
namespace WorkerServiceDemo
{
    public class Worker : BackgroundService
    {
        private readonly ILogger<Worker> _logger;
        public Worker(ILogger<Worker> logger)
        {
            _logger = logger;
        }
        public override async Task StartAsync(CancellationToken cancellationToken)
        {
            await base.StartAsync(cancellationToken);
        }
        public override async Task StopAsync(CancellationToken cancellationToken)
        {
            await base.StopAsync(cancellationToken);
        }
        protected override async Task ExecuteAsync(CancellationToken stoppingToken)
        {
            while (!stoppingToken.IsCancellationRequested)
            {
                _logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now);
                await Task.Delay(1000, stoppingToken);
            }
        }
        public override void Dispose()
        {
        }
    }
}
登录后复制

通过在Program.cs的IHostBuilder.ConfigureServices方法中使用AddHostedService扩展方法注册了该服务:

services.AddHostedService<Worker>();
登录后复制

安装WorkerServices模板后,可以使用UseWindowsService扩展方法在IHostBuilder中配置Windows服务:

using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace WorkerServiceDemo
{
    public class Program
    {
        public static void Main(string[] args)
        {
            CreateHostBuilder(args).Build().Run();
        }
        public static IHostBuilder CreateHostBuilder(string[] args)
        {
            return Host.CreateDefaultBuilder(args)
                .ConfigureServices((hostContext, services) =>
                {
                    services.AddHostedService<Worker>();
                }).UseWindowsService();
        }
    }
}
登录后复制

.NET Core 3.1和WorkerServices构建Windows服务

现在可以部署Windows服务了。发布方式如下:

dotnet restore
dotnet publish
登录后复制

使用sc.exe工具直接部署exe文件发布Windows服务:

即构数智人
即构数智人

即构数智人是由即构科技推出的AI虚拟数字人视频创作平台,支持数字人形象定制、短视频创作、数字人直播等。

即构数智人 36
查看详情 即构数智人
sc.exe create DemoWorker binpath= publish\xxxx.exe
sc.exe start WorkerServicesName
登录后复制

部署exe文件:

WorkerServicesName.exe install
WorkerServicesName.exe start
登录后复制

使用sc.exe停止和删除服务:

sc.exe stop WorkerServicesName
sc.exe delete WorkerServicesName
登录后复制

非sc.exe停止和删除服务:

WorkerServicesName stop
WorkerServicesName uninstall
登录后复制

添加Microsoft.Extensions.Hosting.Systemd NuGet软件包后,可以在IHostBuilder中添加UseSystemd()方法:

public static IHostBuilder CreateHostBuilder(string[] args)
{
    return Host.CreateDefaultBuilder(args)
        .ConfigureServices((hostContext, services) =>
        {
            services.AddHostedService<Worker>();
        }).UseSystemd();
}
登录后复制

.NET Core 3.1和WorkerServices构建Windows服务

在Linux上设置为守护程序,请参考以下链接:

https://www.php.cn/link/3a3fbf606d98da42ecaf1ed523ee083c

https://www.php.cn/link/2562e666dd1a56d065589ec818bda84c

以上就是.NET Core 3.1和WorkerServices构建Windows服务的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号