ASP.NET CORE 2.2 Проблема развертывания - PullRequest
0 голосов
/ 25 января 2019

У меня самая странная проблема, и я понятия не имею, почему. При развертывании API-интерфейса .net core 2.2 на локальном сервере IIS появляется следующее сообщение об ошибке:

Ошибка HTTP 502,5 - Ошибка запуска ANCM вне процесса

После проверки журнала событий I это ошибка, которую я нахожу:

Application: dotnet.exe
CoreCLR Version: 4.6.27207.3
Description: The process was terminated due to an unhandled exception.
Exception Info: System.InvalidOperationException: No service for type 'Digitise.Infrastructure.Services.DatabaseMigrator' has been registered.
   at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService(IServiceProvider provider, Type serviceType)
   at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService[T](IServiceProvider provider)
   at Digitise.ApiBase.BaseProgram.Initialise(String[] args, IWebHost host) in C:\Projects\Digitise.AspNetCore\Digitise.ApiBase\BaseProgram.cs:line 17
   at Digitise.Api.Program.Main(String[] args) in C:\Projects\Digitise.AspNetCore\Digitise.Api\Program.cs:line 27

Кажется, что DI не работает правильно! Странная вещь, если я запускаю api.exe или dotnet api.dll, API работает отлично: /

У кого-нибудь есть идеи? :)

Program.cs

public class Program    
    {
            public static object _lock = new object();
            public static bool _init = false;

            public static void Main(string[] args)
            {
                var host = CreateWebHostBuilder(args);
                Initialise(args, host);
            }

            public static IWebHost CreateWebHostBuilder(string[] args) =>
                WebHost.CreateDefaultBuilder(args)
                    .UseStartup<Startup>()
                    //.UseIISIntegration()
                    .UseIIS()
                    .UseNLog()
                    .UseShutdownTimeout(TimeSpan.FromSeconds(10))
                    .Build();

            public static void Initialise(string[] args, IWebHost host)
            {
                var logger = NLogBuilder.ConfigureNLog(Path.Combine(Directory.GetCurrentDirectory(), "NLog.config")).GetCurrentClassLogger();
                try
                {
                    logger.Debug("App init");

                    using (var scope = host.Services.CreateScope())
                    {
                        var services = scope.ServiceProvider;
                        try
                        {
                            if (!_init)
                            {
                                lock (_lock)
                                {
                                    if (!_init)
                                    {
                                        lock (_lock)
                                        {
                                            services.GetRequiredService<DatabaseMigrator>().Migrate();
                                        }
                                    }
                                }
                            }
                        }
                        catch (Exception ex)
                        {
                            logger.Error(ex, "An error occurred while starting up the app.");
                            throw;
                        }
                    }

                    host.Run();
                }
                catch (Exception e)
                {
                    logger.Error(e, "Stopped app due to exception");
                    throw;
                }
            }
        }

DatabaseMigrator.cs

public class DatabaseMigrator
    {
        private readonly TenantDbContext _tenantDbContext;
        private readonly IOptions<DatabaseConfiguration> _databaseConfig;
        private readonly ILogger<DatabaseMigrator> _logger;
        private readonly AdminTenantDbInitialiser _adminTenantDbInitialiser;

        public DatabaseMigrator(TenantDbContext tenantDbContext, IOptions<DatabaseConfiguration> databaseConfig, ILogger<DatabaseMigrator> logger, AdminTenantDbInitialiser adminTenantDbInitialiser)
        {
            _tenantDbContext = tenantDbContext;
            _databaseConfig = databaseConfig;
            _logger = logger;
            _adminTenantDbInitialiser = adminTenantDbInitialiser;
        }

        public void Migrate()
        {
           //migration logic
        }
    }

Ответы [ 2 ]

0 голосов
/ 03 апреля 2019

В моем случае проблема начала обнаруживаться после обновления некоторых пакетов Nuget. Помогла установка последней версии .NET Core SDK.

0 голосов
/ 07 марта 2019

Я только что пережил много боли, решая подобную проблему.Уверен, проблема в том, что вы используете Directory.GetCurrentDirectory(), это делает странные вещи при работе с внутрипроцессным хостингом, как в IIS.Я заменил его на Assembly.GetExecutingAssembly().Location, и все работало нормально.

Подсказка пришла от Несколько классов запуска ядра Dotnet с внутрипроцессным хостингом

...