Click here to Skip to main content
Click here to Skip to main content

Stopping and Starting Services Automatically During Builds

, 11 Mar 2008 CPOL
Rate this:
Please Sign up or sign in to vote.
How to make your life a little easier while developing a service

Introduction

One of the most basic facts when developing applications under Windows is that as long as a program is running, its DLLs and executable cannot be overwritten. Probably you've experienced this behaviour. You want to replace a DLL with an updated version and Windows tells you, "The process cannot access the file because it is being used by another process." A look at the taskbar shows that in fact the application the DLL belongs to is still running.

While developing a desktop application, this usually isn't a big problem - you modify the code, rebuild and start debugging. When the code has to be modified, you simply shut down your application, perform the code changes and restart the application (or use edit and continue in the cases where this is supported).

Now if you don't develop a desktop application but a Windows Service, things usually tend to become a little clumsy, since you don't start and stop your service in the same way you start and stop a desktop application.

Project Setup

ProjectSetup.jpg

For this article, I've set up a simple solution where the service is used to publish a .NET remoting server. ISample defines the interface for the remoting server; Sample is the actual server implementation and SampleService is the service responsible for publishing the remoting server. In order to be able to run and test the service, of course, it has to be installed first using InstallUtil.

First Approach

I guess the most common approach is to install the service directly from the Debug directory. Once the service has been installed, you can start it via the service control panel. Everything is fine up to now, but when you have to modify your code (the service implementation, for example) the shortcomings of this approach become visible: rebuilding the SampleService project will fail because the service is still running, thus locking Sample.dll and preventing Visual Studio from overwriting the DLL.

So you have to switch to the services control panel again, stop the service, go back to Visual Studio, rebuild again, go back to the control panel and restart the service. Honestly, I've followed this tedious manual pattern for quite a long time without giving it a second thought. But finally I asked myself, "Can't I simplify this whole procedure?"

Making It Easier

The solution turned out to be amazingly simple. The much underrated pre-build action comes to the rescue: I want the service to be stopped before rebuild and to be started once the rebuild is complete.

BuildEvents1.jpg

Services can be started and stopped with two simple commands from the command line: net start <ServiceName> and net stop <ServiceName>. By adding the command to stop the service during pre-build and the command to start the service during post-build, you don't have to perform these steps manually (and you cannot forget to perform them!) every time you rebuild.

Applying Final Polish

So now the service is being stopped automatically before the DLLs are being replaced and restarted automatically once the rebuild has been successful.

Unfortunately, net stop returns a non-zero exit code when the service in question has not been started (yet). Because every pre-build action has to be executed successfully (with zero exit code) before Visual Studio continues the build process, you won't be able to build your solution unless the service is running. So we have to tweak the pre-build action a little. We don't care whether or not the service is running before rebuilding. All we want is that the service is not running during rebuild! By adding a simple echo. to the pre-build action, we can ignore the exit code of net stop and give Visual Studio the exit code of echo instead (which always is zero).

BuildEvents2.jpg

Conclusion

By adding two simple lines to your build events you can simplify the process of developing a Windows service application. As an alternative for using net start/net stop you can also use sc.exe to control services from the command line. The syntax is almost identical for these commands, so it's more or less a matter of taste which command to use.

History

  • 9th March, 2008 -- Original version posted
  • 11th March, 2008 -- Article edited and moved to The Code Project main article base

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

mav.northwind
Software Developer (Senior) 4voice AG
Germany Germany
No Biography provided

Comments and Discussions

 
GeneralGreat Tip! PinmemberBrent_JR18-Mar-08 0:57 
GeneralAlternate Technique Pinmemberricecake11-Mar-08 5:35 
GeneralRe: Alternate Technique PinmemberLee Humphries12-Mar-08 18:11 
Hey I recognise those comments from here:
http://www.codeproject.com/KB/dotnet/DebugWinServices.aspx[^]
Big Grin | :-D
 
Glad it's been useful for you.
GeneralRe: Alternate Technique Pinmemberricecake13-Mar-08 4:33 
GeneralGood Article, But ... Pinmemberscott.simmons11-Mar-08 4:37 
GeneralRe: Good Article, But ... Pinmembermav.northwind11-Mar-08 5:56 
GeneralThat's ok, but... PinmemberRubensFarias9-Mar-08 13:49 
GeneralRe: That's ok, but... Pinmembermav.northwind9-Mar-08 20:56 
GeneralRe: That's ok, but... PinmemberRubensFarias10-Mar-08 0:53 
GeneralRe: That's ok, but... PinmemberRubensFarias16-Mar-08 4:58 
GeneralA very useful tip! PinmemberRavi Bhavnani9-Mar-08 11:46 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.1411023.1 | Last Updated 11 Mar 2008
Article Copyright 2008 by mav.northwind
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid