我有两个进程,需要在同一台PC机和不同PC机上进行通信。在本地情况下,进程通信是在进程A
和进程B
等不同进程之间进行的。
在远程情况下,它将在两个运行在不同PC机上的进程A
实例中。
我将从头开始创建它们,我想知道最好的方法是什么。我知道RMI和套接字,但我想知道所描述的情况,并考虑到如果有标准的方法/库,交换的消息很小,API的数量也很小。
任何建议都非常欢迎。
@EJP注释后的更新:
我感兴趣的是1)以一种轻松的方式实现对通信的需求,因为公开的API非常小,而且消息也很小(如果可能的话)使用和学习一个新的流行框架(我已经知道了RMI和套接字)。
发布于 2013-01-11 07:44:49
如果您只是在寻找消息传递框架,那么有一堆可用的信息,如
但是,当您使用第三方框架时,您将向应用程序添加额外的依赖项。如果情况非常简单,也许编写TCP客户机/服务器对于客户机/服务器范例就足够了,或者如果您正在寻找publisher/订户范例,那么您可以考虑使用UDP多播。如果您希望能够将数据封送和解编组到缓冲区,并使用典型的JAVA将其发送到网络,您只需要您的数据类来扩展Serializable。
发布于 2013-01-11 07:28:05
我强烈建议你去看看。从我使用过的所有技术(web服务、RMI、XML、Corba )来看,它是我目前最喜欢的技术。所涉及的主要步骤是:
通常,您可以在大约30行代码中将服务器和客户端组合在一起。就速度和可靠性而言,我从来没有失败过。
发布于 2013-01-11 07:23:26
JMX是一个很好的选择。
例子:
http://www.javalobby.org/java/forums/t49130.html
IMB JMX示例
http://alvinalexander.com/blog/post/java/source-code-java-jmx-hello-world-application
https://stackoverflow.com/questions/14273487
复制相似问题