Windows在C#(.NET 2.0)中的进程间通信

时间:2020-03-05 18:49:29  来源:igfitidea点击:

我以前从未在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/