java 远程通讯之 rmi

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)