Search code examples
c#.netwindows-servicesshutdownlong-running-processes

Can a Windows Service take hours to shutdown gracefully?


We have a .NET Windows service that shovels a lot of highly critical data from A to B in a transactional manner. We also need to make sure that all external compontents used in the service are unallocated correctly and everything cleaned up before shutting down the service itself. This can take hours! The reason for this is that the service needs to wait on an external component's callback, which arrives 2, 3, or 4 hours later.

  1. is it possible for Windows to wait so long for a service to shutdown gracefully?
  2. are there options in a service where I can dictate what happens when the service is being shutdown by the operating system, e.g. prevent the shutdown altogether?
  3. also, as another scenario, what happens if the server needs to reboot? Can it wait hours for the service?
  4. Is there a limit on how long the OS will wait on the service before killing it?

Solution

  • You can use CanStop, CanShutdown, CanHandlePowerEvent to be notified when the computer is shutting down and respond adequately.

    Use the ServiceBase.RequestAdditionalTime method to request additional time to terminate your thread:

    protected override void OnShutdown() 
    {
        base.RequestAdditionalTime(MaxTimeout);
        serviceCore.OnShutdown();
        Stop(); 
    }
    

    If your OnShutdown() blocks for longer than 20 seconds (default value stored in the registry HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\WaitToKillServiceTimeout), your service will be marked as unresponsive and killed.

    There is a good blog post from the BCL team on that subject that I recommend.