Springboot?RestTemplate設(shè)置超時時間的簡單方法
RestTemplate未設(shè)置超時時間,導(dǎo)致RabbitMQ隊列大量堆積,消費者假死,不進(jìn)行消費,類似線程堵塞。
排查:
從日志排查問題,在從進(jìn)入消費者到結(jié)束期間,會調(diào)用業(yè)務(wù)服務(wù),然而通過開始時間至結(jié)束時間,花費的時間竟然高達(dá)100多秒,查看業(yè)務(wù)服務(wù)未發(fā)現(xiàn)異常。出現(xiàn)這種問題的原因也有可能在消費期間網(wǎng)絡(luò)波動導(dǎo)致HTTP連接出現(xiàn)問題,一直處于等待狀態(tài)。由此判斷可能是HTTP超時時間未設(shè)置導(dǎo)致的問題。
本文生產(chǎn)環(huán)境Springboot版本 2.1.5.RELEASE,采用的是Java config配置
Java Config配置
@Configuration
public class RestTemplateConfig {
@Bean
public RestTemplate getRestTemplate() {
//配置HTTP超時時間
HttpComponentsClientHttpRequestFactory httpRequestFactory = new HttpComponentsClientHttpRequestFactory();
httpRequestFactory.setConnectionRequestTimeout(6000);
httpRequestFactory.setConnectTimeout(6000);
httpRequestFactory.setReadTimeout(6000);
return new RestTemplate(httpRequestFactory);
}
}
配置文件指定
custom.rest.connection.connection-request-timeout=3000 custom.rest.connection.connect-timeout=3000 custom.rest.connection.read-timeout=3000
@Configuration
public class AppConfig{
@Bean
@ConfigurationProperties(prefix = "custom.rest.connection")
public HttpComponentsClientHttpRequestFactory customHttpRequestFactory() {
return new HttpComponentsClientHttpRequestFactory();
}
??????? @Bean
public RestTemplate customRestTemplate(){
return new RestTemplate(customHttpRequestFactory());
}
}
重新部署后消費者迅速開始消費,堆積的消息已經(jīng)消費完。
RestTemplate 設(shè)置超時時間注意點
1、保證系統(tǒng)中只有一個RestTemplate的配置;不然可能與你的預(yù)期不一致。
2、永遠(yuǎn)不要太相信自己寫的代碼;多打印日志才能真正知道調(diào)用時間;
long s = System.currentTimeMillis();
try {
responseEntity = restTemplate.exchange();
} catch (Exception e) {
long costTime = System.currentTimeMillis()-s;
log.error("調(diào)用**服務(wù)異常,花費時間:{},錯誤:{}",costTime, e.getMessage(), e);
}
總結(jié)
到此這篇關(guān)于Springboot RestTemplate設(shè)置超時時間的文章就介紹到這了,更多相關(guān)Springboot RestTemplate設(shè)置超時時間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java8中Stream流求最大值最小值的實現(xiàn)示例
本文主要介紹了Java8中Stream流求最大值最小值的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
springboot多數(shù)據(jù)源使用@Qualifier自動注入無效的解決
這篇文章主要介紹了springboot多數(shù)據(jù)源使用@Qualifier自動注入無效的解決,具有很好的參考價值,希望對大家有所幫助。也希望大家多多支持腳本之家2021-11-11
java通過Callable和Future來接收線程池的執(zhí)行結(jié)果
這篇文章主要介紹了java通過Callable和Future來接收線程池的執(zhí)行結(jié)果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
SpringBoot整合Redis的哨兵模式的實現(xiàn)
Redis提供了哨兵模式來處理主從切換和故障轉(zhuǎn)移,本文主要介紹了SpringBoot整合Redis的哨兵模式的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08
SpringBoot集成shiro,MyRealm中無法@Autowired注入Service的問題
今天小編就為大家分享一篇關(guān)于SpringBoot集成shiro,MyRealm中無法@Autowired注入Service的問題,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03

