Java网络编程设置请求超时

一、引言

随着企业系统的发展,应用多采用分布式结构,严重依赖于网络的稳定性。但由于网络天生的不稳定性,系统开发过程中需要考虑网络不稳定情况下如何保证应用的鲁棒性。 设置网络超时是其中一种保证应用健壮性的手段。 设置网络超时设置后,请求在设定时间能未完成将被强制终止,保证程序不出现无限制的线程阻塞情况,有效的提高了应用的可用性。

二、未设置超时与设置超时情况对比

1. 网络请求图例:

网络请求超时案例

2. 设置超时时间后,请求图例:

网络请求超时案例-设置超时

三、常见的网络超时设置

1. httpclient超时设置(Spring bean)

  1. 配置

     <bean id="multiThreadedHttpConnectionManager"
       class="org.apache.commons.httpclient.MultiThreadedHttpConnectionManager">
       <property name="params">
         <bean
           class="org.apache.commons.httpclient.params.HttpConnectionManagerParams">
           <property name="maxTotalConnections" value="${maxTotalConnections:300}" />
           <property name="defaultMaxConnectionsPerHost" value="${defaultMaxConnectionsPerHost:300}" />
           <!-- 连接超时,毫秒。 -->
           <property name="connectionTimeout" value="${connectTimeout:10000}" />
           <!-- socket超时,毫秒。 -->
           <property name="soTimeout" value="${readTimeout:600000}" />
           <property name="staleCheckingEnabled" value="${staleCheckingEnabled:true}" />
         </bean>
       </property>
     </bean>
     
     <bean id="httpClient" class="org.apache.commons.httpclient.HttpClient">
       <constructor-arg>
         <ref bean="multiThreadedHttpConnectionManager" />
       </constructor-arg>
     </bean>
    
  2. httpinvoker使用场景

配置HttpInvokerRequestExecutor,覆盖HttpInvokerProxyFactoryBean中默认使用的的SimpleHttpInvokerRequestExecutor,并配置网络超时。见《配置》。

    <bean id="httpInvokerRequestExecutor"
      class="org.springframework.remoting.httpinvoker.CommonsHttpInvokerRequestExecutor">
      <constructor-arg>
        <ref bean="httpClient" />
      </constructor-arg>
    </bean>
    
    <bean id="xxxxService"
      class="org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean">
      <property name="serviceUrl" value="${xxxxServiceUrl}" />
      <property name="serviceInterface" value="com.xxxxService" />
      <property name="httpInvokerRequestExecutor" ref="httpInvokerRequestExecutor" />
    </bean>

2. HttpClient超时设置(硬编码)

  1. 样例

     RequestConfig config = RequestConfig.custom()
         .setSocketTimeout(1*1000)  // socket套接字超时,毫秒。
         .setConnectionRequestTimeout(1*1000) //使用连接池来管理连接时,从连接池获取连接的超时时间,毫秒。
         .setConnectTimeout(5*1000) // 连接建立超时,毫秒。
         .build();
     CloseableHttpClient httpClient = HttpClients.custom()
         .setDefaultRequestConfig(config) //
         .build();
     CloseableHttpResponse httpResponse = httpClient.execute(httpGet); // 执行请求
    

3. 邮件超时设置

基于Spring框架开发的项目可以很方便的使用
org.springframework.mail.javamail.JavaMailSenderImpl实现邮件提醒等功能。

  1. 配置

     <bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl"
       p:host="${mailSender.host}" p:username="${mailSender.username}"
       p:password="${mailSender.password}">
       <property name="javaMailProperties">
         <props>
           <prop key="mail.smtp.auth">${mailSender.smtp.auth:true}
           </prop>
           <prop key="mail.smtp.timeout">${mailSender.smtp.timeout:10000}
           </prop>
           <prop key="mail.smtp.connectiontimeout">${mailSender.smtp.connectiontimeout:10000}
           </prop>
         </props>
       </property>
     </bean>
    
  2. javaMailProperties说明

    1. mail.smtp.timeout : smtp邮件服务器读取超时。
    2. mail.smtp.connectiontimeout : smtp邮件服务器连接超时。
    3. mail.smtp.auth : 是否认证用户。

    注: property参数名列表可查询JavaMail API documentation。

  3. 参考

    1. JavaMail API documentation
    2. JavaMail Reference Implementation
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,853评论 18 139
  • 本文包括:1、名词解释2、邮件收发过程3、JavaMail 知识概要4、发送一封符合 MIME 协议的 JavaM...
    廖少少阅读 4,075评论 2 13
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,935评论 6 342
  • HttpClient整理资料 1、httpClient HttpClient是Apache中的一个开源的项目。它实...
    小白豆豆5阅读 30,088评论 5 38
  • application的配置属性。 这些属性是否生效取决于对应的组件是否声明为Spring应用程序上下文里的Bea...
    新签名阅读 5,417评论 1 27