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.
- is it possible for Windows to wait so long for a service to shutdown gracefully?
- 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?
- also, as another scenario, what happens if the server needs to reboot? Can it wait hours for the service?
- Is there a limit on how long the OS will wait on the service before killing it?
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?
Once the win service is started then this process will run continuously in background.
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.
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.
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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With