Some Services stop automatically if they are not in use by other services
I got this error and it was because the hard drive had filled up. It could be anything that keeps the service from running.
I could fix this by adjusting the service properties.
I noticed that all of the other working services were using "Local System" as "Log On As", but the service having issue was using "Local Service". You can fix this by going to the list of services, right click on desired service, click properties on context menu and then change "Log On As" to "Local system account" if it is not the same as shown in below image.
This is generally the result of one of two things - either (a) your OnStart()
method is throwing an exception or (b) the OnStart()
method is not kicking off a thread to do work.
If the problem is (a), then the obvious solution is to debug the service to identify what is going wrong. At a minimum, put a try-catch
block around the contents of the OnStart()
method and log an error to the system event log when an exception occurs. Then you can see the details in the Windows Event Viewer.
If the problem is (b), then you need to create a thread that actually does something. The thread needs to be a foreground thread (as opposed to a background thread) to prevent the service from shutting down. A typical OnStart()
method looks like this:
private System.Threading.Thread _thread;
protected override void OnStart(string[] args)
{
try
{
// Uncomment this line to debug...
//System.Diagnostics.Debugger.Break();
// Create the thread object that will do the service's work.
_thread = new System.Threading.Thread(DoWork);
// Start the thread.
_thread.Start();
// Log an event to indicate successful start.
EventLog.WriteEntry("Successful start.", EventLogEntryType.Information);
}
catch (Exception ex)
{
// Log the exception.
EventLog.WriteEntry(ex.Message, EventLogEntryType.Error);
}
}
private void DoWork()
{
// Do the service work here...
}