`
m635674608
  • 浏览: 5029094 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

java 远程通讯之 rmi

    博客分类:
  • java
 
阅读更多

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远程通讯可选技术及原理.docx

    Java远程通讯技术是构建分布式系统的关键,涉及到多种协议和实现方式。本文主要探讨了Java领域中常见的几种远程通讯技术,包括RMI、MINA、ESB、Burlap、Hessian、SOAP、EJB和JMS等。这些技术各有特点,适用于不同的...

    Java远程通讯技术及原理分析共18页.pdf.zip

    首先,我们要理解什么是Java远程通讯(Java Remote Method Invocation,简称RMI)。RMI是Java平台提供的一种标准API,允许Java对象在不同的JVM之间调用方法。RMI的核心在于,它能够透明地处理网络通信,使得开发者...

    一个完整的Java RMI通讯的例子

    Java Remote Method Invocation (RMI) 是Java平台提供的一种分布式计算技术,它允许在不同网络节点上的Java对象之间进行远程调用。在这个例子中,我们将深入理解RMI的基本概念、工作原理以及如何创建一个完整的RMI...

    java远程通讯技术及简单实现.docx

    Java远程通讯技术是分布式服务框架中的关键组成部分,它允许不同机器上的应用程序相互通信,实现服务的远程调用。在Java领域,有多种技术可以实现远程通讯,包括RMI(Remote Method Invocation)、XML-RPC、SOAP、...

    javaRMI完整版.pdf

    Java Remote Method Invocation(RMI)是一种分布式对象技术,允许使用 Java 编写分布式对象,不同的 Java 虚拟机(JVM)之间进行对象间的通讯。这使得应用程序(Application)可以远程调用方法,共享各个系统的资源...

    RMI通讯模型(java编写)

    Java RMI(Remote Method Invocation,远程方法调用)是一种在分布式环境中进行对象间通信的技术,它允许一个Java对象调用另一个在不同JVM上的对象的方法。RMI是Java平台的标准部分,为网络上的对象提供了透明的交互...

    JavaRMI示例程序

    我的博客《Java中的RMI(远程方法调用)》的示例代码

    Java RMI中文规范

    Java RMI(Remote Method Invocation,远程方法调用)是Java平台中用于构建分布式对象系统的关键技术。它允许Java应用程序在不同Java虚拟机(JVM)之间进行远程方法调用,这些虚拟机可能位于同一台计算机或网络上的...

    RMI远程过程调用

    RMI采用JRMP(Java Remote Method Protocol)通讯协议,是构建在TCP/IP协议上的一种远程调用方法。它允许运行在一个Java虚拟机上的对象调用运行在另一个Java虚拟机上的对象方法,从而使编程人员可以方便地在网络环境...

    java进程通讯

    java进程间通讯机制代码 RMI(Remote Method Invocation)是一种基于Java的分布式编程模型,为java程序提供远程访问服务接口。

    基于Java的远程方法调用及其应用

    远程方法调用(Remote Method Invocation,简称RMI)是Java平台提供的一个强大工具,允许一个Java虚拟机(JVM)上的对象调用另一个JVM上的对象的方法。这种能力对于构建分布式系统特别有用,尤其是在企业级应用中。 ...

    分布式实验报告RMI.docx

    RMI 是一种分布式对象通讯机制,允许运行在一个 Java 虚拟机的对象调用运行在另一个 Java 虚拟机上对象的方法。 一、RMI 基本概念 RMI 是一种分布式对象通讯机制,允许运行在一个 Java 虚拟机的对象调用运行在另一...

    RMI远程调用视频教材

    RMI是Remote Method Invocation(远程方法调用)的 所写。它允许一个Java程序调用网络中另一台计算机上的Java方法,就如调用本机的方法一样。实现RMI调用的程序和被调用的方法,都必须是Java代码,即客户端和服务器...

    Java rmi远程方法调用基本用法解析

    Java RMI 远程方法调用基本用法解析 Java RMI(Remote Method Invocation,远程方法调用)是一种Java语言中用于实现远程方法调用的技术。它允许在不同的Java虚拟机中运行的对象之间进行通信和交互。下面将对Java ...

    java 聊天系统(带远程控制)

    为了实现远程控制,可能需要使用Java的RMI(Remote Method Invocation)或者第三方库如JNA(Java Native Access)来调用本地操作系统接口。 在安全性方面,聊天系统必须保护用户的隐私,防止未授权访问和数据泄露。...

Global site tag (gtag.js) - Google Analytics