java.lang.IllegalStateException: Connection pool shut down
最近使用HttpClient 4.5 使用?CloseableHttpClient 發(fā)起連接后,使用CloseableHttpResponse 接受返回結(jié)果,結(jié)果就報(bào)錯(cuò)了,上網(wǎng)查了下,有位stackoverflow的大兄弟說,只要將:
CloseableHttpClient httpClient = HttpClients.createDefault(); 改為: CloseableHttpClient httpClient = HttpClients.custom().setConnectionManager(connManager).setConnectionManagerShared(true).build();就可以整正常執(zhí)行了,于是,用之,果然不報(bào)錯(cuò)了,但是為什么呢?以下是大兄弟的原文解釋:
I was having a similar error when I came across this thread and this seemed to fix the issue for me. I know this is an old question, but adding thoughts for others for future reference.
I'm not 100% sure as to why this fix works as the documentation around this is pretty awful. It was a lot of trial and error with what I was testing to get to this solution. From what I can
gather though, this fix works because it is then using a shared connection pool in the background, which means that connections remain open for use.
關(guān)鍵是最后一句話:大概意思是,后臺使用一個(gè)共享連接池,供剩下打開的連接去使用
?
原文地址:https://stackoverflow.com/questions/41744410/executorservice-performing-rest-requests
感謝下這位大兄弟
?
apache 官方的建議是,創(chuàng)建連接池,并為每一個(gè)接口URL分配一個(gè)線程,去執(zhí)行,還給出了許多高并發(fā)訪問的編碼技巧
原文:https://hc.apache.org/httpcomponents-client-ga/tutorial/html/connmgmt.html
那么,使用HttpClient 4.5連接池的正確姿勢是什么呢?
原作者地址:https://my.oschina.net/xlj44400/blog/711341
?
摘要: HttpClient 是 Apache Jakarta Common 下的子項(xiàng)目,可以用來提供高效的、最新的、功能豐富的支持 HTTP 協(xié)議的客戶端編程工具包,并且它支持 HTTP 協(xié)議最新的版本和建議HttpClient簡介
HttpClient 是 Apache Jakarta Common 下的子項(xiàng)目,可以用來提供高效的、最新的、功能豐富的支持 HTTP 協(xié)議的客戶端編程工具包,并且它支持 HTTP 協(xié)議最新的版本和建議。HttpClient支持的功能如下:
- 支持Http0.9、Http1.0和Http1.1協(xié)議。
- 實(shí)現(xiàn)了Http全部的方法(GET,POST,PUT,HEAD 等)。
- 支持HTTPS協(xié)議。
- 支持代理服務(wù)器。
- 提供安全認(rèn)證方案。
- 提供連接池以便重用連接。
- 連接管理器支持多線程應(yīng)用。支持設(shè)置最大連接數(shù),同時(shí)支持設(shè)置每個(gè)主機(jī)的最大連接數(shù),發(fā)現(xiàn)并關(guān)閉過期的連接。
- 在http1.0和http1.1中利用KeepAlive保持長連接。
以前是commons-httpclient,后面被Apache HttpComponents取代,目前版本4.5.x,我們現(xiàn)在用的就是4.5版本
HttpClient連接池使用
為什么要用Http連接池:
1、降低延遲:如果不采用連接池,每次連接發(fā)起Http請求的時(shí)候都會(huì)重新建立TCP連接(經(jīng)歷3次握手),用完就會(huì)關(guān)閉連接(4次揮手),如果采用連接池則減少了這部分時(shí)間損耗2、支持更大的并發(fā):如果不采用連接池,每次連接都會(huì)打開一個(gè)端口,在大并發(fā)的情況下系統(tǒng)的端口資源很快就會(huì)被用完,導(dǎo)致無法建立新的連接- 默認(rèn)http協(xié)議:
- https協(xié)議:
- httpClient使用
-
連接池使用注意事項(xiàng):
1. 連接池中連接都是在發(fā)起請求的時(shí)候建立,并且都是長連接2. HttpResponse input.close();作用就是將用完的連接釋放,下次請求可以復(fù)用,這里特別注意的是,如果不使用in.close();而僅僅使用httpClient.close();結(jié)果就是連接會(huì)被關(guān)閉,并且不能被復(fù)用,這樣就失去了采用連接池的意義。3. 連接池釋放連接的時(shí)候,并不會(huì)直接對TCP連接的狀態(tài)有任何改變,只是維護(hù)了兩個(gè)Set,leased和avaliabled,leased代表被占用的連接集合,avaliabled代表可用的連接的集合,釋放連接的時(shí)候僅僅是將連接從leased中remove掉了,并把連接放到avaliabled集合中
打印的狀態(tài):
INFO c.m.p.u.h.HttpClientUtils[72] - now client pool [leased: 0; pending: 0; available: 0; max: 50]
leased :the number of persistent connections tracked by the connection manager currently being used to execute requests. available :the number idle persistent connections. pending : the number of connection requests being blocked awaiting a free connection. max: the maximum number of allowed persistent connections.HttpClient 4.5超時(shí)設(shè)置
4.5版本中,這兩個(gè)參數(shù)的設(shè)置都抽象到了RequestConfig中,由相應(yīng)的Builder構(gòu)建,具體的例子如下:
CloseableHttpClient httpclient = HttpClients.createDefault(); HttpGet httpGet = new HttpGet("http://stackoverflow.com/"); RequestConfig requestConfig = RequestConfig.custom() .setConnectTimeout(5000).setConnectionRequestTimeout(1000) .setSocketTimeout(5000).build(); httpGet.setConfig(requestConfig); CloseableHttpResponse response = httpclient.execute(httpGet); System.out.println("得到的結(jié)果:" + response.getStatusLine());//得到請求結(jié)果 HttpEntity entity = response.getEntity();//得到請求回來的數(shù)據(jù)- setConnectTimeout:設(shè)置連接超時(shí)時(shí)間,單位毫秒。ConnectTimeoutException
- setConnectionRequestTimeout:設(shè)置從connect Manager獲取Connection 超時(shí)時(shí)間,單位毫秒。這個(gè)屬性是新加的屬性,因?yàn)槟壳鞍姹臼强梢怨蚕磉B接池的。ConnectionPoolTimeout
- setSocketTimeout:請求獲取數(shù)據(jù)的超時(shí)時(shí)間,單位毫秒。 如果訪問一個(gè)接口,多少時(shí)間內(nèi)無法返回?cái)?shù)據(jù),就直接放棄此次調(diào)用。SocketTimeoutException
- 上面3個(gè)時(shí)間4.5版本默認(rèn)是-1,就是不限,如果不設(shè)置就會(huì)一直等待
轉(zhuǎn)載于:https://www.cnblogs.com/Eillot/p/9042284.html
總結(jié)
以上是生活随笔為你收集整理的java.lang.IllegalStateException: Connection pool shut down的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在物欲横流,心浮气躁的今天,毕业生靠什么
- 下一篇: 【洛谷】【二分答案+最短路】P1462