其实Spring RMI 提供自动重连,这样的话,如果服务端的程序重启,就不会影响到客户端.
而且大家应该知道,Spring 在容器启动的时候,就实例化所有BEAN,所以提醒大家,如果不一定用到,或者可以等下加载的,可以设置为延时加载的。
对于Spring RMI的实现我就不多说了,如果不知道的请看:
http://feng-henry.iteye.com/blog/1090339
下面是具体实现。
/**
* 自定一个SCOKECT连接,可配置超时时间
* @author Henry
*/
public class RMICustomClientSocketFactory implements RMIClientSocketFactory {
private int timeout;
/**
* 设置超时时间
* @param timeout
*/
public void setTimeout(int timeout) {
this.timeout = timeout;
}
public Socket createSocket(String host, int port) throws IOException {
Socket socket = new Socket(host, port);
socket.setSoTimeout(timeout);
return socket;
}
}
Spring配置文件如下:
<bean id="rmiClientSocketFactory" class="com.rmi.RMICustomClientSocketFactory">
<property name="timeout" value="5000"></property>
</bean>
<bean id="rmiService" class="org.springframework.remoting.rmi.RmiProxyFactoryBean">
<property name="serviceUrl" value="rmi://127.0.0.1:10999/Demo"></property>
<property name="serviceInterface" value="com.demo.IDemoRMIServer"></property>
<!-- setting refresh connect -->
<property name="refreshStubOnConnectFailure" value="true"></property>
<property name="lookupStubOnStartup" value="false"></property>
<property name="registryClientSocketFactory" ref="rmiClientSocketFactory"></property>
</bean>
lookupStubOnStartup : 这个属性是表示,不在容器启动的时候创建与Server端的连接;
refreshStubOnConnectFailure : 这个属性是表示是否连接出错时自动重连;
registryClientSocketFactory : 这个是客户端与服务端创建SOCKECT的一个工厂。
它只需要是实现RMIClientSocketFactory 接口的类就行。
RMIClientSocketFactory 的 原码如下:
public interface RMIClientSocketFactory {
/**
* Create a client socket connected to the specified host and port.
* @param host the host name
* @param port the port number
* @return a socket connected to the specified host and port.
* @exception IOException if an I/O error occurs during socket creation
* @since 1.2
*/
public Socket createSocket(String host, int port)
throws IOException;
}
当然以上这些属性都在RmiProxyFactoryBean的超类 RmiClientInterceptor 里。这个源码太长,大家如果想深入了解,可以阅读此类源码。
分享到:
相关推荐
* Dubbo提供了多种超时设置方式,包括ConnectionTimeout、Timeout等 * 超时设置可以根据实际情况选择和配置 Dubbo的通信协议: * Dubbo支持多种通信协议,包括Dubbo、RMI、HTTP等 * 通信协议可以根据实际情况选择...
- timeout:方法调用超时时间 - retries:失败重试次数,默认2次 - loadbalance:负载均衡策略,默认随机 - actives:消费者端的最大并发调用限制 13. **Dubbo启动时服务不可用的处理?** 如果在启动时依赖的...
12. **Provider 对 Consumer 的影响**:在 Provider 端可以配置 Consumer 端的属性,如超时时间(timeout)、重试次数(retries)、负载均衡策略(loadbalance)和最大并发调用限制(actives)。 13. **服务不可用...
- **timeout**: 远程调用服务超时时间(毫秒)。 - **retries**: 远程服务调用重试次数(不包括首次调用),设为0表示不重试。 - **loadbalance**: 负载均衡策略,支持`random`(随机)、`roundrobin`(轮询)、`...
1) timeout:方法调用超时时间 2) retries:失败重试次数,默认2次 3) loadbalance:负载均衡算法,默认随机 4) actives:消费者端最大并发调用限制 【Dubbo启动时依赖服务不可用会怎样?】 默认情况下,Dubbo在...
例如,可以通过`timeout`属性设置服务调用的超时时间,通过`retries`控制重试次数,通过`failfast`、`fallback`或`failsafe`策略应对失败情况。 总的来说,Dubbo作为一个强大的RPC框架,不仅简化了分布式服务的开发...
7. **配置元素与属性**:dubbo.xsd文件中定义了如、、、等配置元素,以及各个元素下的属性,如interface、version、group、timeout、retries等,这些都是编写正确Dubbo配置文件的关键。 8. **服务监控(Monitor)**...
- `jnp.timeout` 和 `jnp.sotimeout`:设置 JNP 协议的超时参数。 **企业命名上下文 (ENC)** 企业命名上下文 (Enterprise Naming Context, ENC) 是 JBoss 中的一个特殊命名空间,用于组织和管理应用程序的资源。ENC...