Springboot?RestTemplate設置超時時間的簡單方法
RestTemplate未設置超時時間,導致RabbitMQ隊列大量堆積,消費者假死,不進行消費,類似線程堵塞。
排查:
從日志排查問題,在從進入消費者到結(jié)束期間,會調(diào)用業(yè)務服務,然而通過開始時間至結(jié)束時間,花費的時間竟然高達100多秒,查看業(yè)務服務未發(fā)現(xiàn)異常。出現(xiàn)這種問題的原因也有可能在消費期間網(wǎng)絡波動導致HTTP連接出現(xiàn)問題,一直處于等待狀態(tài)。由此判斷可能是HTTP超時時間未設置導致的問題。
本文生產(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 設置超時時間注意點
1、保證系統(tǒng)中只有一個RestTemplate的配置;不然可能與你的預期不一致。
2、永遠不要太相信自己寫的代碼;多打印日志才能真正知道調(diào)用時間;
long s = System.currentTimeMillis(); try { responseEntity = restTemplate.exchange(); } catch (Exception e) { long costTime = System.currentTimeMillis()-s; log.error("調(diào)用**服務異常,花費時間:{},錯誤:{}",costTime, e.getMessage(), e); }
總結(jié)
到此這篇關于Springboot RestTemplate設置超時時間的文章就介紹到這了,更多相關Springboot RestTemplate設置超時時間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java線程池prestartCoreThread prestartAllCoreThreads的預熱源碼解讀
這篇文章主要介紹了java線程池prestartCoreThread prestartAllCoreThreads的預熱源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10SpringData JPA中查詢接口Repository的使用
本文主要介紹了SpringData JPA中查詢接口Repository的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07SpringMVC的處理器適配器-HandlerAdapter的用法及說明
這篇文章主要介紹了SpringMVC的處理器適配器-HandlerAdapter的用法及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12SpringBoot整合Spring Security構(gòu)建安全的Web應用
pring Security是一個強大的身份驗證和訪問控制框架,本文主要介紹了SpringBoot整合Spring Security構(gòu)建安全的Web應用,具有一定的參考價值,感興趣的可以了解一下2024-01-01springboot接口參數(shù)校驗JSR303的實現(xiàn)
本文主要介紹了springboot接口參數(shù)校驗JSR303的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08Spring MVC中基于自定義Editor的表單數(shù)據(jù)處理技巧分享
Spring MVC中基于自定義Editor的表單數(shù)據(jù)處理技巧。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12詳解Spark?Sql在UDF中如何引用外部數(shù)據(jù)
這篇文章主要為大家介紹了詳解Spark?Sql在UDF中如何引用外部數(shù)據(jù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02