看了《J2EE without EJB》的remote章节,忍不住写点代码试试,看看Spring的实现到底多巧妙。
1.先测试RMI服务的发布,测试代码如下:
Spring的context配置文件如下:
[code]
<beans>
<bean id="myService" class="test.spring.remote.rmi.MyServiceImpl" />
<bean id="serviceExporter" class="org.springframework.remoting.rmi.RmiServiceExporter">
<property name="serviceName">
<value>myService</value>
</property>
<property name="service">
<ref bean="myService" />
</property>
<property name="serviceInterface">
<value>test.spring.remote.rmi.MyService</value>
</property>
<property name="registryPort">
<value>1199</value>
</property>
</bean>
</beans>
[/code]
运行出错了.原来用以发布rmi的接口应该是pojo形式的MyBusinessInterface,而不是那个继承自Remote的MyService,修改自己的context配置文件:
再运行,可以了。
2.再继续测试客户端调用,先修改context配置如下:
添加客户端调用:
运行TestSpringRmi,成功.
经过一番浅尝辄止,初步得出几个结论:
1.Spring对RMI的支持果然很不错,在Cglib等工具的支持下,使用RMI终于可以同Naming、rmic和stub告别了。
2.用以发布RMI的接口不能从java.rmi.Remote继承而来,否则就会出现“Stub class not found”的错误,原因有待深究。
3.Spring的BeanFactory创建bean实例是有序的,向RMI、JNDI、WebService等注册服务性质的应用,同一应用中的客户端要根据其依赖性调整配置顺序。
--------------------------------------------------------------------------------------------------
最新调整:
[b]
1.按上述过程之后,rmi链接在交互方任意一方重启后,可能出新首次链接不上的情况.
为了避免上述情况的发生,请参照下图进行设置.
2.注意事项,对方的java接口应该传非remote的接口,包结构可以随意. 但是对方的接口中调用到的实体类包结构必须一致,同时必须实现序列化.[/b]
[img]http://dl.iteye.com/upload/attachment/573563/92e4df82-a279-35db-9acd-5f5743cea926.jpg[/img]
1.先测试RMI服务的发布,测试代码如下:
//remote Service
package test.spring.remote.rmi;
public interface MyService extends java.rmi.Remot {
public void doSomething() throws java.rmi.RemoteException;
}
//pojo Service
package test.spring.remote.rmi;
public interface MyBusinessInterface {
public void doSomething();
}
//实现类
package test.spring.remote.rmi;
public class MyServiceImpl implements MyService, MyBusinessInterface {
public void doSomething() {
System.out.println("MyServiceImpl.doSomething()");
}
}
Spring的context配置文件如下:
[code]
<beans>
<bean id="myService" class="test.spring.remote.rmi.MyServiceImpl" />
<bean id="serviceExporter" class="org.springframework.remoting.rmi.RmiServiceExporter">
<property name="serviceName">
<value>myService</value>
</property>
<property name="service">
<ref bean="myService" />
</property>
<property name="serviceInterface">
<value>test.spring.remote.rmi.MyService</value>
</property>
<property name="registryPort">
<value>1199</value>
</property>
</bean>
</beans>
[/code]
运行出错了.原来用以发布rmi的接口应该是pojo形式的MyBusinessInterface,而不是那个继承自Remote的MyService,修改自己的context配置文件:
<beans>
<bean id="myService" class="test.spring.remote.rmi.MyServiceImpl" />
<bean id="serviceExporter" class="org.springframework.remoting.rmi.RmiServiceExporter">
<property name="serviceName">
<value>myService</value>
</property>
<property name="service">
<ref bean="myService" />
</property>
<property name="serviceInterface">
<!-- <value>test.spring.remote.rmi.MyService</value> -->
<value>test.spring.remote.rmi.MyBusinessInterface</value>
</property>
<property name="registryPort">
<value>1199</value>
</property>
</bean>
</beans>
再运行,可以了。
2.再继续测试客户端调用,先修改context配置如下:
<beans>
<!--服务器端开始-->
<bean id="myService" class="test.spring.remote.rmi.MyServiceImpl" />
<bean id="serviceExporter" class="org.springframework.remoting.rmi.RmiServiceExporter">
<property name="serviceName">
<value>myService</value>
</property>
<property name="service">
<ref bean="myService" />
</property>
<property name="serviceInterface">
<!-- <value>test.spring.remote.rmi.MyService</value> -->
<value>test.spring.remote.rmi.MyBusinessInterface</value>
</property>
<property name="registryPort">
<value>1199</value>
</property>
</bean>
<!--服务器端结束-->
<!--客户端开始-->
<bean id="rmiService"
class="org.springframework.remoting.rmi.RmiProxyFactoryBean">
<property name="serviceInterface">
<value>test.spring.remote.rmi.MyBusinessInterface</value>
</property>
<property name="serviceUrl">
<value>rmi://localhost:1199/myService</value>
</property>
</bean>
<!--客户端结束-->
</beans>
添加客户端调用:
package test.spring.remote.rmi;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class TestSpringRmi {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("spring-remote.xml");
MyBusinessInterface service = (MyBusinessInterface) context.getBean("rmiService");
service.doSomething();
}
}
运行TestSpringRmi,成功.
经过一番浅尝辄止,初步得出几个结论:
1.Spring对RMI的支持果然很不错,在Cglib等工具的支持下,使用RMI终于可以同Naming、rmic和stub告别了。
2.用以发布RMI的接口不能从java.rmi.Remote继承而来,否则就会出现“Stub class not found”的错误,原因有待深究。
3.Spring的BeanFactory创建bean实例是有序的,向RMI、JNDI、WebService等注册服务性质的应用,同一应用中的客户端要根据其依赖性调整配置顺序。
--------------------------------------------------------------------------------------------------
最新调整:
[b]
1.按上述过程之后,rmi链接在交互方任意一方重启后,可能出新首次链接不上的情况.
为了避免上述情况的发生,请参照下图进行设置.
2.注意事项,对方的java接口应该传非remote的接口,包结构可以随意. 但是对方的接口中调用到的实体类包结构必须一致,同时必须实现序列化.[/b]
[img]http://dl.iteye.com/upload/attachment/573563/92e4df82-a279-35db-9acd-5f5743cea926.jpg[/img]