Interprocess communication for Windows in C# (.NET 2.0)我以前从未在Windows上进行过IPC。 目前,我正在开发一对程序,一个标准的GUI / CLI应用程序和一个Windows服务。 该应用必须告知服务该怎么做。 因此,假设仅在本地进行通信,这两个过程的最佳通信方法是什么? 最好的地方定义为更健壮,更不易出错,而不是性能最高或最容易编写的地方。 代码示例将非常受欢迎,但不是必需的:-) 请注意,我在询问使用什么,标准TCP套接字,命名管道或仅其他一些通信方式。 谢谢! .Net中的IPC可以使用以下方法实现: 世界足球联合会 使用命名管道需要.Net 3.0及更高版本。 代码示例
远程处理 .Net 1.0发布的原始IPC框架。我相信远程处理将不再得到积极发展,建议您改用WCF。 代码示例 通过远程处理进行进程间通信-使用TCP通道 资源资源
使用csharptest-net RpcLibrary的Win32 RPC 我最近遇到一个项目,该项目包装了Win32 RPC库,并创建了一个.net类库,该库可用于本地和远程RPC。 项目主页:http://csharptest.net/projects/rpclibrary/ MSDN参考:
还有一个在库顶部运行的google协议缓冲区rpc客户端:https://code.google.com/p/protobuf-csharp-rpc/ WM_COPYDATA 为了完整起见,还可以将WIN32方法与WM_COPYDATA消息一起使用。在.Net 1.1中,我之前曾使用过此方法来创建一个单实例应用程序,该应用程序从Windows资源管理器中打开多个文件。 资源资源
插座 使用自定义协议(较难) 仅对于本地用户,我们已成功使用命名管道。避免了TCP的开销,并且(至少对于.NET)效率很高,同时还具有不错的API。 与Windows服务通信的标准方法是使用服务控制代码。 Windows服务可以接收从0到255的代码。0-127保留给系统。 128到255可用于自定义命令。 如果您需要使用数据库,xml,文件,tcp,http等将复杂的对象发送到服务,则除了用于发送控制命令(如重载配置,过程项等)外,还应使用此控制代码。 还有其他功能可用,例如查询服务。请参阅Windows服务文档和api。 Windows Services in C#: Sending Commands to your Windows Service (part 7) 由于您限于.Net 2.0,因此WCF可能不是一个选择。您可以将具有共享内存的.Net远程处理用作同一计算机上应用程序域之间的基础通信机制。使用这种方法,您可以轻松地将进程放在不同的计算机上,并用网络协议替换共享内存协议。 我想补充一下讨论。如果这是外面的方法,请责骂我-但是信号量(或多个信号量)不能用于基本的交流吗? 最好的选择是使用WCF。您将能够在Windows服务中创建服务主机,并公开GUI应用程序可以使用的定义明确的界面。如果愿意,WCF将允许您通过命名管道进行通信,或者可以选择任何其他通信协议,例如TCP,HTTP等。使用WCF,您将获得强大的工具支持和大量可用信息。 |