java.lang.IllegalStateException: Invalid use of BasicClientConnManager: connection still allocated

最近項目中壓測,利用httpclient訪問接口報錯蔼囊。錯誤信息如下:


image.png
  • 錯誤原因分析:
    并發(fā)調(diào)用同一個httpclient去請求數(shù)據(jù)導(dǎo)致焚志,當(dāng)上一個post|get請求尚未結(jié)束時,又啟新的線程再次使用該httpclient請求數(shù)據(jù)畏鼓。

  • 解決方案:
    采用線程池酱酬,從線程池中獲取httpclient。

改用線程池中訪問https\http鏈接類型接口完整代碼云矫,使用方法:

  • 工具類
public class HttpClientUtils {
    private static CloseableHttpClient HTTPCLIENT;
    private static Logger logger = LoggerFactory.getLogger(HttpClientUtils.class);
    private static RequestConfig REQUESTCONFIG = RequestConfig.custom()
            .setSocketTimeout(1000)
            .setConnectTimeout(1000)
            .setConnectionRequestTimeout(1000)
            .build();
    static PoolingHttpClientConnectionManager cm;

    static {
        PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager();

        HTTPCLIENT = HttpClientBuilder.create().setRetryHandler((exception, executionCount, context) -> {
            return false;
        }).setDefaultRequestConfig(REQUESTCONFIG).setConnectionManager(cm).build();

    }


    public static String get(String url) throws IOException {
        try {

            HttpGet httpget = new HttpGet(url);
            ResponseHandler<String> responseHandler = new ResponseHandler<String>() {
                @Override
                public String handleResponse(
                        final HttpResponse response) throws ClientProtocolException, IOException {
                    int status = response.getStatusLine().getStatusCode();
                    if (status >= 200 && status < 300) {
                        HttpEntity entity = response.getEntity();
                        return entity != null ? EntityUtils.toString(entity) : null;
                    } else {
                        logger.error("請求{},出現(xiàn)了錯誤{}", url, status);
                        return "出錯了";
                        //throw new ClientProtocolException("Unexpected response status: " + status);
                    }
                }

            };
            String responseBody = HTTPCLIENT.execute(httpget, responseHandler);
            return responseBody;
        } finally {

        }
    }

    public static String post(String url,Map map) throws IOException {
        String result = null;
        HttpPost post = new HttpPost(url);
//        System.out.println(map);
        post.setHeader("content-type","application/json");
        String param = JSON.toJSONString(map);
        StringEntity entity = new StringEntity(param,"UTF-8");
        post.setEntity(entity);
        try {
            HttpResponse response = HTTPCLIENT.execute(post);
            result = EntityUtils.toString(response.getEntity(),"UTF-8");
            // System.out.println(result);
           return result;

        } catch (IOException e) {
            e.printStackTrace();
        }

        return "";

    }


    public static HttpResponse postResponse(String url,Map map) throws IOException {
        String result = null;
        HttpPost post = new HttpPost(url);
//        System.out.println(map);
        post.setHeader("content-type","application/json");
        String param = JSON.toJSONString(map);
        StringEntity entity = new StringEntity(param,"UTF-8");
        post.setEntity(entity);
        try {
            HttpResponse response = HTTPCLIENT.execute(post);
            System.out.println(response.getAllHeaders());
            System.out.println(response.getEntity());
            result = EntityUtils.toString(response.getEntity(),"UTF-8");
            // System.out.println(result);
            return response;

        } catch (IOException e) {
            e.printStackTrace();
        }

        return null;

    }
}
  • 調(diào)接口
HttpPost post = new HttpPost(url);
String result = HttpClientUtils.post(url, map);
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末膳沽,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子让禀,更是在濱河造成了極大的恐慌挑社,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件巡揍,死亡現(xiàn)場離奇詭異痛阻,居然都是意外死亡,警方通過查閱死者的電腦和手機腮敌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門阱当,熙熙樓的掌柜王于貴愁眉苦臉地迎上來俏扩,“玉大人,你說我怎么就攤上這事弊添÷嫉” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長紊册。 經(jīng)常有香客問我牙寞,道長,這世上最難降的妖魔是什么彼水? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮极舔,結(jié)果婚禮上凤覆,老公的妹妹穿的比我還像新娘。我一直安慰自己拆魏,他們只是感情好盯桦,可當(dāng)我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著渤刃,像睡著了一般拥峦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上卖子,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天略号,我揣著相機與錄音,去河邊找鬼洋闽。 笑死玄柠,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的诫舅。 我是一名探鬼主播羽利,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼刊懈!你這毒婦竟也來了这弧?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤俏讹,失蹤者是張志新(化名)和其女友劉穎当宴,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泽疆,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡户矢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了殉疼。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梯浪。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡捌年,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出挂洛,到底是詐尸還是另有隱情礼预,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布虏劲,位于F島的核電站托酸,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏柒巫。R本人自食惡果不足惜励堡,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望堡掏。 院中可真熱鬧应结,春花似錦、人聲如沸泉唁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽亭畜。三九已至扮休,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間拴鸵,已是汗流浹背肛炮。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留宝踪,地道東北人。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓碍扔,卻偏偏與公主長得像瘩燥,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子不同,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容