`
fengchong719
  • 浏览: 83410 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Spring RMI 超时(Timeout) 和 自动重连

阅读更多
其实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 里。这个源码太长,大家如果想深入了解,可以阅读此类源码。
分享到:
评论
3 楼 fengchong719 2012-02-28  
iamct 写道
你好 试过这个方法 但是好像一直存在问题  超时的情况与我设置的时间不一致
比较郁闷

你把你的代码实现给我看看。
2 楼 iamct 2011-11-20  
你好 试过这个方法 但是好像一直存在问题  超时的情况与我设置的时间不一致
比较郁闷
1 楼 yazh2636 2011-10-29  
正好用到,感谢分享

相关推荐

    Dubbo面试题(2020最新版).pdf

    * Dubbo提供了多种超时设置方式,包括ConnectionTimeout、Timeout等 * 超时设置可以根据实际情况选择和配置 Dubbo的通信协议: * Dubbo支持多种通信协议,包括Dubbo、RMI、HTTP等 * 通信协议可以根据实际情况选择...

    Java面试资料之Dubbo相关

    - timeout:方法调用超时时间 - retries:失败重试次数,默认2次 - loadbalance:负载均衡策略,默认随机 - actives:消费者端的最大并发调用限制 13. **Dubbo启动时服务不可用的处理?** 如果在启动时依赖的...

    史上最全 40 道 Dubbo 面试题及答案

    12. **Provider 对 Consumer 的影响**:在 Provider 端可以配置 Consumer 端的属性,如超时时间(timeout)、重试次数(retries)、负载均衡策略(loadbalance)和最大并发调用限制(actives)。 13. **服务不可用...

    Dubbo配置说明

    - **timeout**: 远程调用服务超时时间(毫秒)。 - **retries**: 远程服务调用重试次数(不包括首次调用),设为0表示不重试。 - **loadbalance**: 负载均衡策略,支持`random`(随机)、`roundrobin`(轮询)、`...

    Dubbo手册.pdf

    1) timeout:方法调用超时时间 2) retries:失败重试次数,默认2次 3) loadbalance:负载均衡算法,默认随机 4) actives:消费者端最大并发调用限制 【Dubbo启动时依赖服务不可用会怎样?】 默认情况下,Dubbo在...

    Dubbo使用示例

    例如,可以通过`timeout`属性设置服务调用的超时时间,通过`retries`控制重试次数,通过`failfast`、`fallback`或`failsafe`策略应对失败情况。 总的来说,Dubbo作为一个强大的RPC框架,不仅简化了分布式服务的开发...

    dubbo.xsd资源

    7. **配置元素与属性**:dubbo.xsd文件中定义了如、、、等配置元素,以及各个元素下的属性,如interface、version、group、timeout、retries等,这些都是编写正确Dubbo配置文件的关键。 8. **服务监控(Monitor)**...

    JBOSS培训资源.ppt

    - `jnp.timeout` 和 `jnp.sotimeout`:设置 JNP 协议的超时参数。 **企业命名上下文 (ENC)** 企业命名上下文 (Enterprise Naming Context, ENC) 是 JBoss 中的一个特殊命名空间,用于组织和管理应用程序的资源。ENC...

Global site tag (gtag.js) - Google Analytics