一、引言
随着企业系统的发展,应用多采用分布式结构,严重依赖于网络的稳定性。但由于网络天生的不稳定性,系统开发过程中需要考虑网络不稳定情况下如何保证应用的鲁棒性。 设置网络超时是其中一种保证应用健壮性的手段。 设置网络超时设置后,请求在设定时间能未完成将被强制终止,保证程序不出现无限制的线程阻塞情况,有效的提高了应用的可用性。
下面话不多说了,来一起看看详细的介绍吧。
二、未设置超时与设置超时情况对比
1. 网络请求图例:
网络请求超时案例
2. 设置超时时间后,请求图例:
网络请求超时案例-设置超时
三、常见的网络超时设置
1. httpclient超时设置(spring bean)
配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<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> |
httpinvoker使用场景
配置httpinvokerrequestexecutor,覆盖httpinvokerproxyfactorybean中默认使用的的simplehttpinvokerrequestexecutor,并配置网络超时。见《配置》。
1
2
3
4
5
6
7
8
9
10
|
<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
2
3
4
5
6
7
8
9
|
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
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<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> |
javamailproperties说明
- mail.smtp.timeout : smtp邮件服务器读取超时。
- mail.smtp.connectiontimeout : smtp邮件服务器连接超时。
- mail.smtp.auth : 是否认证用户。
注: property参数名列表可查询javamail api documentation。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
参考
原文链接:http://www.jianshu.com/p/b9365dfa66f4