Служба на локальном компьютере запущена, затем остановлена

Я создал Службу, которую я установил на нескольких машинах. Все они работают нормально, кроме одного. Когда я пытаюсь запустить службу через Windows Services, я получаю следующую ошибку:

The My.Service service on Local Computer started and then stopped. Some services stop automatically if they are not in use by other services or programs.

Я видел другие посты, предлагающие изменить свойства входа службы для входа в систему как локальная системная учетная запись - я уже делаю это.

Просмотрщик событий дает мне эту информацию:

Application: myProject.exe
Framework Version: v4.0.30319
Description: The process was terminated due to an unhandled exception.
Exception Info: System.AggregateException
Stack:
   at Microsoft.AspNetCore.Server.Kestrel.KestrelServer.Start[[Microsoft.AspNetCore.Hosting.Internal.HostingApplication+Context, Microsoft.AspNetCore.Hosting, Version=1.1.1.0, Culture=neutral, PublicKeyToken=adb9793829ddae60]](Microsoft.AspNetCore.Hosting.Server.IHttpApplication`1<Context>)
   at Microsoft.AspNetCore.Hosting.Internal.WebHost.Start()
   at Microsoft.AspNetCore.Hosting.WebHostExtensions.Run(Microsoft.AspNetCore.Hosting.IWebHost, System.Threading.CancellationToken, System.String)
   at Microsoft.AspNetCore.Hosting.WebHostExtensions.Run(Microsoft.AspNetCore.Hosting.IWebHost)
   at Nexus.Startup.Main(System.String[])

Я попытался запустить службу вручную из командной строки и передать --debug и получил это сообщение об ошибке:

09:05:47.289 [1] ERROR - 
System.AggregateException: One or more errors occurred. ---> System.NullReferenceException: Object reference not set to an instance of an object.
   at Microsoft.AspNetCore.Server.Kestrel.Internal.Http.Listener.<DisposeAsync>d__13.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Microsoft.AspNetCore.Server.Kestrel.Internal.Http.ListenerPrimary.<DisposeAsync>d__20.MoveNext()
   --- End of inner exception stack trace ---
   at System.Threading.Tasks.Task.WaitAll(Task[] tasks, Int32 millisecondsTimeout, CancellationToken cancellationToken)
   at System.Threading.Tasks.Task.WaitAll(Task[] tasks, Int32 millisecondsTimeout)
   at System.Threading.Tasks.Task.WaitAll(Task[] tasks, TimeSpan timeout)
   at Microsoft.AspNetCore.Server.Kestrel.Internal.KestrelEngine.DisposeListeners(List`1 listeners)
   at Microsoft.AspNetCore.Server.Kestrel.Internal.KestrelEngine.CreateServer(ServerAddress address)
   at Microsoft.AspNetCore.Server.Kestrel.KestrelServer.Start[TContext](IHttpApplication`1 application)
   at Microsoft.AspNetCore.Hosting.Internal.WebHost.Start()
   at Microsoft.AspNetCore.Hosting.WebHostExtensions.Run(IWebHost host, CancellationToken token, String shutdownMessage)
   at Microsoft.AspNetCore.Hosting.WebHostExtensions.Run(IWebHost host)
   at MyProject.Startup.Main(String[] args) in D:\bamboo-home\xml-data\build-dir\163841\CUT-CUP-CR\repos\myProject\Startup.cs:line 42
---> (Inner Exception #0) System.NullReferenceException: Object reference not set to an instance of an object.
   at Microsoft.AspNetCore.Server.Kestrel.Internal.Http.Listener.<DisposeAsync>d__13.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Microsoft.AspNetCore.Server.Kestrel.Internal.Http.ListenerPrimary.<DisposeAsync>d__20.MoveNext()<---

Я довольно запутался, так как этот сервис прекрасно запускается на других машинах.

Вот мой основной метод Startup.cs:

        public static void Main(string[] args)
    {
        var exePath = Process.GetCurrentProcess().MainModule.FileName;
        var directoryPath = Path.GetDirectoryName(exePath);

        if (Debugger.IsAttached || args.Contains("--debug"))
        {
            var host = new WebHostBuilder()
               .CaptureStartupErrors(true)
               .UseKestrel()
               .UseUrls("http://localhost:5000")
               .UseContentRoot(Directory.GetCurrentDirectory())
               .UseIISIntegration()
               .UseStartup<Startup>()
               .Build();
            host.Run();
        }
        else
        {
            var host = new WebHostBuilder()
                .UseKestrel()
                .UseUrls("http://localhost:5000")
                .UseContentRoot(directoryPath)
                .UseIISIntegration()
                .UseStartup<Startup>()
                .Build();
            host.RunAsService();
        }
    }

1 ответ

@ScottChamberlain Да, я прошел в --debug - Roka545

Вы не можете сделать это. Run() блокирующий вызов, который не позволяет полностью запустить службу Windows. Тебе всегда нужно делать RunAsSevice() из службы, даже если вы отлаживаете. Шаблон, который я обычно делаю, это

    if (args.Contains("--console"))
    {
        var host = new WebHostBuilder()
           .CaptureStartupErrors(true)
           .UseKestrel()
           .UseUrls("http://localhost:5000")
           .UseContentRoot(Directory.GetCurrentDirectory())
           .UseIISIntegration()
           .UseStartup<Startup>()
           .Build();
        host.Run();
    }
    else
    {
        var host = new WebHostBuilder()
            .UseKestrel()
            .UseUrls("http://localhost:5000")
            .UseContentRoot(directoryPath)
            .UseIISIntegration()
            .UseStartup<Startup>()
            .Build();
        host.RunAsService();
    }

Таким образом, отладчик подключен или нет, служба запускается как служба, когда вы запускаете ее из службы. Если вы хотите запустить его отдельно (как в F5 от visual studio), вы пропустите --console к аргументам.

Другие вопросы по тегам