Windows在C#(.NET 2.0)中的进程间通信
我以前从未在Windows上进行过IPC。目前,我正在开发一对程序,一个标准的GUI / CLI应用程序和一个Windows服务。该应用必须告知服务该怎么做。因此,假设通信仅在本地进行,那么这两个过程的最佳通信方法是什么?
最好的地方定义为更健壮,更不易出错,而不是性能最高或者最容易编写的地方。
代码示例将非常受欢迎,但不是必需的:-)
请注意,我在询问使用什么,标准TCP套接字,命名管道或者仅其他一些通信方式。
谢谢!
解决方案
回答
仅对于本地用户,我们已成功使用命名管道。避免了TCP的开销,并且(至少对于.NET)效率很高,同时还具有不错的API。
回答
.Net中的IPC可以使用以下方法实现:
使用命名管道需要.Net 3.0及更高版本。
代码示例
- WCF类NetNamedPipeBinding可以用于同一台机器上的进程间通信。此类的MSDN文档包括涵盖此方案的代码示例http://msdn.microsoft.com/zh-cn/library/system.servicemodel.netnamedpipebinding.aspx
.Net 1.0发布的原始IPC框架。我相信远程处理将不再被积极开发,因此建议我们改用WCF。
代码示例
通过远程处理的进程间通信使用tcp通道
资源
- GenuineChannels,出售包含共享内存通道的远程处理工具包。 http://www.genuinechannels.com/Index.aspx
- Ingo Rammer撰写了权威的.Net远程处理书《 Advanced .NET Remoting,第二版》
我最近遇到一个包装了Win32 RPC库并创建了可用于本地和远程RPC的.net类库的项目。
项目主页:http://csharptest.net/projects/rpclibrary/
MSDN参考:
- RPC的工作方式:http://technet.microsoft.com/zh-cn/library/cc738291(v = ws.10).aspx
- RPC功能:http://msdn.microsoft.com/zh-cn/library/aa378623(v=VS.85).aspx
还有一个在库顶部运行的google协议缓冲区rpc客户端:https://code.google.com/p/protobuf-csharp-rpc/
为了完整起见,还可以将WIN32方法与WM_COPYDATA消息一起使用。在.Net 1.1中,我之前曾使用过这种方法来创建一个单实例应用程序,该应用程序从Windows资源管理器中打开多个文件。
资源
- MSDN-WM_COPYDATA
- 代码示例
- PInvoke.net声明
使用自定义协议(较难)
回答
由于我们限于.Net 2.0,因此WCF可能不是一个选择。我们可以将具有共享内存的.Net远程处理用作同一台计算机上应用程序域之间的基础通信机制。使用这种方法,我们可以轻松地将进程放在不同的计算机上,并用网络协议替换共享内存协议。
回答
最好的选择是使用WCF。我们将能够在Windows服务中创建服务主机,并公开GUI应用程序可以使用的定义明确的界面。如果愿意,WCF将允许我们通过命名管道进行通信,或者可以选择任何其他通信协议,例如TCP,HTTP等。使用WCF,我们将获得强大的工具支持和大量可用信息。
回答
与Windows服务通信的标准方法是使用服务控制代码。 Windows服务可以接收从0到255的代码。0-127保留给系统。 128到255可用于自定义命令。
如果我们需要使用数据库,xml,文件,tcp,http等将复杂的对象发送到服务,则除了用于发送控制命令(如重载配置,过程项等)外,还应使用此控制代码。
还有其他可用功能,例如查询服务。请参阅Windows服务文档和api。
http://arcanecode.com/2007/05/30/windows-services-in-c-sending-commands-to-your-windows-service-part-7/