Asp.NetCore 3.1demo发布使用Windows服务

  

Core之Windows服务

使用测试之前,先来简单了解一下 window自带的sc命令

========install.bat
set serviceName=你的服务名称
set serviceFilePath=C:\CoreDemo\WorkerService\bin\Debug\netcoreapp3.0\MyWorkerService.exe
set serviceDescription=服务描述

sc create 你的服务名称  BinPath=C:\CoreDemo\WorkerService\bin\Debug\netcoreapp3.0\MyWorkerService.exe
sc config 你的服务名称   start=auto  
sc description 你的服务名称  服务描述信息
sc start  你的服务名称
pause

========unstall.bat
set serviceName=你的服务名称
sc stop   你的服务名称
sc delete 你的服务名称
pause

======================= 创建服务 >sc create 你的服务名称 BinPath=C:\CoreDemo\WorkerService\bin\Debug\netcoreapp3.0\MyWorkerService.exe 启动服务 >sc start 你的服务名称 停止服务 >sc stop 你的服务名称 删除服务 >sc delete 你的服务名称
添加服务描述

>sc description 你的服务名称 "描述"
>sc description mylogservice "mylog日志服务" ## 改变服务的启动方式 手动/自动/禁用 sc config 你的服务名称 start= demand/auto/disabled

全部code流程步骤如下:

1导包:
    /*
       <ItemGroup>
          <PackageReference Include="Microsoft.Extensions.Hosting" Version="5.0.0" />
          <PackageReference Include="Microsoft.Extensions.Hosting.WindowsServices" Version="5.0.1" />
       </ItemGroup>
     */
     

2 Program code
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace NetCore_Windows服务
{
    using Microsoft.Extensions.DependencyInjection;
    using Microsoft.Extensions.Hosting;
    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>();
                }).UseWindowsService();
    }
}



// 3 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 NetCore_Windows服务
{
    using System.IO;
    public class Worker : BackgroundService
    {
        private readonly ILogger<Worker> _logger;

        public Worker(ILogger<Worker> logger)
        {
            _logger = logger;
            string newPath = GetLogFilePath();
            if (!File.Exists(newPath))
            {
                var filrStream = File.Create(newPath);
                filrStream.Close();
            }
        }
        public override  Task StartAsync(CancellationToken cancellationToken)
        {
            string newPath = GetLogFilePath();
            File.AppendAllLines(newPath, new List<string> { $"=======StartAsync:{DateTime.Now}" });
            return base.StartAsync(cancellationToken);
        }

        private static string GetLogFilePath()
        {
            var curentDurectory = AppDomain.CurrentDomain.BaseDirectory;
            string newPath = curentDurectory + "/Logs/1.txt";
            return newPath;
        }

        public override Task StopAsync(CancellationToken cancellationToken)
        {
            string newPath = GetLogFilePath();
            File.AppendAllLines(newPath, new List<string> { $"=======StopAsync:{DateTime.Now}" });
            return base.StopAsync(cancellationToken);
        }
        protected override async Task ExecuteAsync(CancellationToken stoppingToken)
        {
            while (!stoppingToken.IsCancellationRequested)
            {
                _logger.LogInformation("Worker running at: {time}", DateTimeOffset.Now);
                string newPath = GetLogFilePath(); ;
                File.AppendAllLines(newPath, new List<string> { $"=======Work现在时间是:{DateTime.Now}=======" });
                await Task.Delay(3000, stoppingToken);
            }
        }
    }
}

测试使用截图如下:(将来我们可能存在多个windows服务,我们命名服务名称和描述时尽量规则统一,便于识别)

 

 

 

 注意事项:以前我们都是使用Windows服务的模板,这里为:(生成的core项目模板有Worker和Program两个主要的文件)

 

相关文章