(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,javavirtual
machine,也就是java虚拟机。
2.只是要运行java程序的话,你只需要jre就可以。正是因为jvm,java才可以在任何平台上运行。3.没有jre是无法运行java程序的液宽戚。windows是不会自带jre的。。。似乎很闹陵久以前有过,不过sun和ms发生巧渗了一点小矛盾。。。。linux系统倒是有的
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)