本篇文章為大家展示了如何解析HttpRequestRetryHandler,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括巢湖網(wǎng)站建設(shè)、巢湖網(wǎng)站制作、巢湖網(wǎng)頁(yè)制作以及巢湖網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,巢湖網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到巢湖省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
在進(jìn)行批量插入到clickhouse數(shù)據(jù)庫(kù)的時(shí)候,出現(xiàn)了這種問題:
21:28:02.022 [pool-5-thread-9] INFO o.a.http.impl.execchain.RetryExec - I/O exception (java.net.SocketException) caught when processing request to {}->http://35.26.59.191:8123: Broken pipe (Write failed) 21:28:02.029 [pool-5-thread-9] INFO o.a.http.impl.execchain.RetryExec - Retrying request to {}->http://35.26.59.191:8123
原先是:斷開的管道
18:34:50.032 [pool-11-thread-10] INFO o.a.http.impl.execchain.RetryExec - I/O exception (java.net.SocketException) caught when processing request to {}->http://35.26.59.191:8123: >斷開的管道 18:34:50.033 [pool-11-thread-10] INFO o.a.http.impl.execchain.RetryExec - Retrying request to {}->http://35.26.59.191:8123
我還以為是連接時(shí)長(zhǎng)過短的原因:(但是并沒有用)
clickhouse.socketTimeout=6000000
后面查閱了相關(guān)資料才發(fā)現(xiàn),HttpClient有默認(rèn)的重試策略。
對(duì)于我們的場(chǎng)景應(yīng)用中的get與post,可以總結(jié)為:
只有發(fā)生IOExecetion時(shí)才會(huì)發(fā)生重試 InterruptedIOException、UnknownHostException、ConnectException、SSLException,發(fā)生這4中異常不重試 get方法可以重試3次,post方法在socket對(duì)應(yīng)的輸出流沒有被write并flush成功時(shí)可以重試3次。 首先分析下不重試的異常:
InterruptedIOException,線程中斷異常 UnknownHostException,找不到對(duì)應(yīng)host ConnectException,找到了host但是建立連接失敗。 SSLException,https認(rèn)證異常 另外,我們還經(jīng)常會(huì)提到兩種超時(shí),連接超時(shí)與讀超時(shí):
java.net.SocketTimeoutException: Read timed out java.net.SocketTimeoutException: connect timed out 這兩種超時(shí)都是SocketTimeoutException,繼承自InterruptedIOException,屬于上面的第1種線程中斷異常,不會(huì)進(jìn)行重試。
由于SocketException extends IOException,所以會(huì)嘗試重試
總結(jié)1.只有發(fā)生IOExecetion時(shí)才會(huì)發(fā)生重試 2.InterruptedIOException、UnknownHostException、ConnectException、SSLException,發(fā)生這4中異常不重試 3.get方法可以重試3次,post方法在socket對(duì)應(yīng)的輸出流沒有被write并flush成功時(shí)可以重試3次。 4.讀/寫超時(shí)不進(jìn)行重試 5.socket傳輸中被重置或關(guān)閉會(huì)進(jìn)行重試 6.以及一些其他的IOException,暫時(shí)分析不出來(lái)。
上述內(nèi)容就是如何解析HttpRequestRetryHandler,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
分享名稱:如何解析HttpRequestRetryHandler
當(dāng)前網(wǎng)址:http://aaarwkj.com/article20/pesjjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、App設(shè)計(jì)、動(dòng)態(tài)網(wǎng)站、關(guān)鍵詞優(yōu)化、虛擬主機(jī)、品牌網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)