java很多分布式框架都是基于远程通信技术实现的,,好像在java远程通信技术中,rmi的性能比较好,。。
rmi每次远程方法调用 是不是 多线程的了。。。。。测试了一下啊
server端
<beans> <bean id="helloService" class="com.logcd.spring.rmi.HelloServiceImpl"/> <!--RmiServiceExporter显示地支持使用RMI调用器暴露任何非RMI服务--> <bean id="serviceExporter" class="org.springframework.remoting.rmi.RmiServiceExporter"> <property name="service" ref="helloService"/> <property name="serviceInterface" value="com.logcd.spring.rmi.HelloService"/> <!--定义要暴露的服务名可以与输出的bean不同名,客户端通过这个名字来调用服务--> <property name="serviceName" value ="HelloService"/> <!--覆盖RMI注册端口号(1099),通常应用服务器也会维护RMI注册,最好不要冲突--> <property name="registryPort" value="1199"/> </bean>
client
<beans> <!--使用RmiProxyFactoryBean连接服务端 这里设置--scope="prototype"也还是单例的>
<bean id="serviceProxy" class="org.springframework.remoting.rmi.RmiProxyFactoryBean" scope="prototype"> <property name="serviceUrl" value="rmi://localhost:1199/HelloService"/> <property name="serviceInterface" value="com.logcd.spring.rmi.HelloService"/> </bean> <bean id="obj" class="java.lang.Object" scope="prototype"> </bean> </beans>
server code
public String doHello(String name) { int i = 0; try { Thread.sleep(1000);//每次都会sleep一秒 System.out.println(Thread.currentThread().getName()); } catch (InterruptedException e) { e.printStackTrace(); } return "Hello , " + name; }
public static void main(String args[]){ ApplicationContext context= new ClassPathXmlApplicationContext( new String[]{"rmi-server.xml"}); }
client code
public static void main(String args[]){ ApplicationContext context= new ClassPathXmlApplicationContext( new String[]{"rmi-client.xml"}); for(int i=0;i<100;i++){ HelloService service = (HelloService)context.getBean("serviceProxy"); Object obj = context.getBean("obj"); System.out.println(service.hashCode()+"----obj=="+obj.hashCode()); System.out.println(service.doHello("logcd")); System.out.println("----------------------"+i); }
client 控制台打印
log4j:WARN No appenders could be found for logger (org.springframework.context.support.ClassPathXmlApplicationContext). log4j:WARN Please initialize the log4j system properly. 269856977----obj==13238549 Hello , logcd ----------------------0 269856977----obj==29131495 Hello , logcd ----------------------1 269856977----obj==14440411 Hello , logcd ----------------------2 269856977----obj==13459339 Hello , logcd ----------------------3 269856977----obj==7579563 Hello , logcd ----------------------4 269856977----obj==23255990 Hello , logcd ----------------------5 269856977----obj==9182681 Hello , logcd ----------------------6 269856977----obj==4898828 Hello , logcd ----------------------7 269856977----obj==22634321
scope="prototype" 设置了。。但是 rmi还是单利的。,,单线程的。。。
server 控制台
RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185 RMI TCP Connection(14)-10.191.72.185
说明 一个client 连接server是一个线程,,,,,,,,
相关推荐
Java远程通讯技术是构建分布式系统的关键,涉及到多种协议和实现方式。本文主要探讨了Java领域中常见的几种远程通讯技术,包括RMI、MINA、ESB、Burlap、Hessian、SOAP、EJB和JMS等。这些技术各有特点,适用于不同的...
首先,我们要理解什么是Java远程通讯(Java Remote Method Invocation,简称RMI)。RMI是Java平台提供的一种标准API,允许Java对象在不同的JVM之间调用方法。RMI的核心在于,它能够透明地处理网络通信,使得开发者...
Java Remote Method Invocation (RMI) 是Java平台提供的一种分布式计算技术,它允许在不同网络节点上的Java对象之间进行远程调用。在这个例子中,我们将深入理解RMI的基本概念、工作原理以及如何创建一个完整的RMI...
Java远程通讯技术是分布式服务框架中的关键组成部分,它允许不同机器上的应用程序相互通信,实现服务的远程调用。在Java领域,有多种技术可以实现远程通讯,包括RMI(Remote Method Invocation)、XML-RPC、SOAP、...
Java Remote Method Invocation(RMI)是一种分布式对象技术,允许使用 Java 编写分布式对象,不同的 Java 虚拟机(JVM)之间进行对象间的通讯。这使得应用程序(Application)可以远程调用方法,共享各个系统的资源...
Java RMI(Remote Method Invocation,远程方法调用)是一种在分布式环境中进行对象间通信的技术,它允许一个Java对象调用另一个在不同JVM上的对象的方法。RMI是Java平台的标准部分,为网络上的对象提供了透明的交互...
我的博客《Java中的RMI(远程方法调用)》的示例代码
Java RMI(Remote Method Invocation,远程方法调用)是Java平台中用于构建分布式对象系统的关键技术。它允许Java应用程序在不同Java虚拟机(JVM)之间进行远程方法调用,这些虚拟机可能位于同一台计算机或网络上的...
RMI采用JRMP(Java Remote Method Protocol)通讯协议,是构建在TCP/IP协议上的一种远程调用方法。它允许运行在一个Java虚拟机上的对象调用运行在另一个Java虚拟机上的对象方法,从而使编程人员可以方便地在网络环境...
java进程间通讯机制代码 RMI(Remote Method Invocation)是一种基于Java的分布式编程模型,为java程序提供远程访问服务接口。
远程方法调用(Remote Method Invocation,简称RMI)是Java平台提供的一个强大工具,允许一个Java虚拟机(JVM)上的对象调用另一个JVM上的对象的方法。这种能力对于构建分布式系统特别有用,尤其是在企业级应用中。 ...
RMI 是一种分布式对象通讯机制,允许运行在一个 Java 虚拟机的对象调用运行在另一个 Java 虚拟机上对象的方法。 一、RMI 基本概念 RMI 是一种分布式对象通讯机制,允许运行在一个 Java 虚拟机的对象调用运行在另一...
RMI是Remote Method Invocation(远程方法调用)的 所写。它允许一个Java程序调用网络中另一台计算机上的Java方法,就如调用本机的方法一样。实现RMI调用的程序和被调用的方法,都必须是Java代码,即客户端和服务器...
Java RMI 远程方法调用基本用法解析 Java RMI(Remote Method Invocation,远程方法调用)是一种Java语言中用于实现远程方法调用的技术。它允许在不同的Java虚拟机中运行的对象之间进行通信和交互。下面将对Java ...
为了实现远程控制,可能需要使用Java的RMI(Remote Method Invocation)或者第三方库如JNA(Java Native Access)来调用本地操作系统接口。 在安全性方面,聊天系统必须保护用户的隐私,防止未授权访问和数据泄露。...