java如何实现进程间的通信

java如何实现进程间的通信,第1张

传统的进程间通信的方式有大致如春没下几种肆森戚:

(1) 管道(PIPE)

(2) 命名管道(FIFO)

(3) 信号量(Semphore)

(4) 消息队列(MessageQueue)

(5) 共享内存(SharedMemory)

(6) Socket

Java如何支持进程间通信。我们把Java进程理解为JVM进程。很明显,传统的这些大部分技术是无法被我们的应用程序利用裂陵了(这些进程间通信都是靠系统调用来实现的)。但是Java也有很多方法可以进行进程间通信的。

除了上面提到的Socket之外,当然首选的IPC可以使用Rmi,或者Corba也可以。另外Java nio的MappedByteBuffer也可以通过内存映射文件来实现进程间通信(共享内存)。

用JMX连接本地JVM上运行的Java程序

JMX由三部分组成:

程序端的Instrumentation, 我把它翻译成可 *** 作的仪器。这部分就是指的MBean. MBean类似于JavaBean。最常用的MBean则是Standard MBean和MXBean.

程序端的JMX agent. 这部分指的是MBean Server. MBean Server则是启动与JVM内的基于各种协议的适配器。用于接收客户端的调遣,然后调用相应的MBeans.

客户端的Remote Management. 这部分则是面向用户的程序。此程序则是MBeans在用户前投影,拦档穗用户 *** 作这些投影,可蠢孝以反映到程序端的MBean中去。这内部的原理则是client通过某种协议调用agent *** 控MBeans.

JMX agent与Remote Management之间是通过协议链接的,这协议可能包含:

HTTP

SNMP

RMI

IIOP

JMX agent中有针对上面协议的各种适配器。可以解析简卜通过相应协议传输过来的数据。Remote Management client则可以用现成的工具,如JConsole, 也可以自己书写java code。

接下来,我们看是一步一步,通过代码示例来熟悉JMX各种特性。

受监管的程序

JMX是用于管理java程序的,为了试验,我们首先需要写一个小程序Echo。然后加入JMX对此程序进行监管。这个程序就是每隔10秒钟,输出一个预先定义好的Message。

首先定义Message类。

定义Echo类

执行Echo,得到每过10秒钟,则会输出一个消息:

<none>

none

by none

1.jvm,java

virtual

machine,也就是java虚拟机。

2.只是要运行java程序的话,你只需要jre就可以。正是因为jvm,java才可以在任何平台上运行。3.没有jre是无法运行java程序的液宽戚。windows是不会自带jre的。。。似乎很闹陵久以前有过,不过sun和ms发生巧渗了一点小矛盾。。。。linux系统倒是有的


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12497891.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存