十年網站開發(fā)經驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網站問題一站解決
本篇文章為大家展示了如何解析HttpRequestRetryHandler,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
創(chuàng)新互聯(lián)公司服務項目包括巢湖網站建設、巢湖網站制作、巢湖網頁制作以及巢湖網絡營銷策劃等。多年來,我們專注于互聯(lián)網行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網行業(yè)的解決方案,巢湖網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到巢湖省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!
在進行批量插入到clickhouse數據庫的時候,出現(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
我還以為是連接時長過短的原因:(但是并沒有用)
clickhouse.socketTimeout=6000000
后面查閱了相關資料才發(fā)現(xiàn),HttpClient有默認的重試策略。
對于我們的場景應用中的get與post,可以總結為:
只有發(fā)生IOExecetion時才會發(fā)生重試 InterruptedIOException、UnknownHostException、ConnectException、SSLException,發(fā)生這4中異常不重試 get方法可以重試3次,post方法在socket對應的輸出流沒有被write并flush成功時可以重試3次。 首先分析下不重試的異常:
InterruptedIOException,線程中斷異常 UnknownHostException,找不到對應host ConnectException,找到了host但是建立連接失敗。 SSLException,https認證異常 另外,我們還經常會提到兩種超時,連接超時與讀超時:
java.net.SocketTimeoutException: Read timed out java.net.SocketTimeoutException: connect timed out 這兩種超時都是SocketTimeoutException,繼承自InterruptedIOException,屬于上面的第1種線程中斷異常,不會進行重試。
由于SocketException extends IOException,所以會嘗試重試
總結1.只有發(fā)生IOExecetion時才會發(fā)生重試 2.InterruptedIOException、UnknownHostException、ConnectException、SSLException,發(fā)生這4中異常不重試 3.get方法可以重試3次,post方法在socket對應的輸出流沒有被write并flush成功時可以重試3次。 4.讀/寫超時不進行重試 5.socket傳輸中被重置或關閉會進行重試 6.以及一些其他的IOException,暫時分析不出來。
上述內容就是如何解析HttpRequestRetryHandler,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。