Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

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?
like image 620
John Avatar asked Sep 16 '11 06:09

John


People also ask

How long does Windows wait for a service to stop?

By default, that fixed period is 180 seconds (3 minutes) — more than enough time for most Windows Services to tidy up and exit gracefully. But what if you need more than three minutes?

Does Windows service run continuously?

Once the win service is started then this process will run continuously in background.

What is a graceful shutdown?

A graceful shutdown is when a computer is turned off by software function and the operating system (OS) is allowed to perform its tasks of safely shutting down processes and closing connections. A hard shutdown is when the computer is forcibly shut down by interruption of power.


2 Answers

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.

like image 55
Nordine Ben Bachir Avatar answered Sep 17 '22 23:09

Nordine Ben Bachir


Yes a service can stall shutdown until it completes, but should it? There are timeout values in the registry for this, what's the OS?

I think you need to decouple the callback from the other component, or buffer data to disk and send in smaller fragments. What happens in a powercut? Or if someone gets fed up waiting and switches off?

If the data is critical manage it outside of memory, and make the process restartable. This will solve your lengthly shutdown process. Likewise a way to poll the component for progress, takes away the dependency on blocking.

like image 21
TheCodeKing Avatar answered Sep 18 '22 23:09

TheCodeKing