tags:

views:

10509

answers:

6

I've never had to do IPC on Windows before. Currently I'm developing a pair of programs, a standard GUI/CLI app and a windows service. The app has to tell the service what to do. So, assuming the communication is local only, what would be the best communication method for these two processes?

Where best is defined as more robust and less error prone, not the most performant nor the easiest to code.

Code examples will be very welcome, but aren't required :-)

Note I'm asking about what to use, a standard TCP socket, named pipes, or some other means of communication only.

Thanks!

A: 

I did some research into it for a project but it never ended up getting used. The keyword you want to look into is remoting. Here's a codeproject article with code examples: http://69.10.233.10/KB/threads/process_communication.aspx

George Mauer
+3  A: 

For local only, we have had success using Named Pipes. Avoids the overhead of TCP, and is pretty much (at least for .NET) as efficient as you can get while also having a decent API to work with.

Guy Starbuck
+21  A: 

IPC in .Net can be achieved using:

WCF

using named pipes requires .Net 3.0 and above.

Code example


Remoting

The original IPC framework released with .Net 1.0. I believe remoting is no longer being actively developed, and you are encouraged to use WCF instead

Code example

Inter-process communication via Remoting - uses a tcp channel

Resources


WM_COPYDATA

For completeness it's also possible to use the WIN32 method with the WM_COPYDATA message. I've used this method before in .Net 1.1 to create a single instance application opening multiple files from windows explorer.

Resources

Sockets

Using a custom protocol (harder)

Edward Wilde
WCF: Just like I'm encouraged to use .NET 3.5 :) Sadly, not an optionRemoting seems like the way to go.
Vinko Vrsalovic
yes and original question was about .net 2.0 :(
Restuta
+1  A: 

Since you are limited to .Net 2.0 WCF is perhaps not an option. You could use .Net remoting with shared memory as the underlying communication mechanism between app domains on the same machine. Using this approach you can easily put your processes on different machines and replace the shared memory protocol with a network protocol.

Brian Ensink
+1  A: 

Your best bet is to use WCF. You will be able to create a service host in the windows service and expose a well defined interface that the GUI application can consume. WCF will let you communicate via named pipes if you choose, or you can choose any other communication protocal like TCP, HTTP, etc. Using WCF you get great tool support and lots of available information.

lfoulkrod
A: 

The standard method of communicating with a windows service is to use service control codes. Windows services can receive codes from 0 to 255. 0-127 is reserved for system. 128 to 255 can be used for custom commands.

If you need to send complex objects to the service use database, xml, file, tcp, http etc. Other than that for sending control commands like reload configuration, process items etc this control codes should be used.

There are additional functionalities available such as querying the service. See Windows service documentation and api.

http://arcanecode.com/2007/05/30/windows-services-in-c-sending-commands-to-your-windows-service-part-7/

Shafqat Ahmed