asp. net core: IApplicationLifetime.ApplicationStopping не запускается - PullRequest
0 голосов
/ 03 августа 2020

Я видел несколько статей о IApplicationLifetime и о том, как я могу запускать выполнение, когда приложение запускается и останавливается, но я, вероятно, что-то пропустил, потому что он просто не запускается. Вот мой обходной путь: я открыл шаблон проекта Container Application для кубернетов, asp. net core 2.2

Program.cs выглядит так, как он был создан:

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;

namespace Kubernetes1
{
    public class Program
    {
        public static void Main(string[] args)
        {
            CreateWebHostBuilder(args).Build().Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseStartup<Startup>();
    }
}

Startup. cs выглядит следующим образом:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Hosting.Internal;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.DependencyInjection;

namespace Kubernetes1
{
    public class Startup
    {
        // This method gets called by the runtime. Use this method to add services to the container.
        // For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
        public void ConfigureServices(IServiceCollection services)
        {
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env, IApplicationLifetime appLifetime)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            //var appLifetime = app.ApplicationServices.GetRequiredService<IApplicationLifetime>();
            appLifetime.ApplicationStopping.Register(() => Console.WriteLine("ApplicationStopping called"));
            appLifetime.ApplicationStopped.Register(() => Console.WriteLine("ApplicationStopped called"));
            app.Run(async (context) =>
            {
                Console.WriteLine("AAA");
            });
        }
    }
}

Все, что я хотел здесь сделать, это запустить приложение в cmd, затем остановить его и увидеть две строки, напечатанные в консоли:

  1. ApplicationStopping вызван
  2. Звонок ApplicationStopped Мне не удалось этого добиться. Есть идеи?

1 Ответ

1 голос
/ 03 августа 2020

в другом окне cmd я набираю: Get-Process -Name *dotnet* | Stop-Process

Stop-Process будет убить процесс, пропуская любое корректное завершение работы приложения.

Когда IApplicationLifetime говорит об остановке приложения, это означает, что приложение было корректно завершено. Есть несколько способов вызвать это, в зависимости от того, как запускается приложение:

  • Когда приложение запущено в консоли: CTRL + C. Например, при запуске через dotnet run или запуске скомпилированного исполняемого файла напрямую.
  • Когда приложение работает в IIS: остановка веб-сайта или пула приложений.
  • Когда приложение работает как Windows Сервис: Остановка сервиса.
...