• 一次线上http接口调用不通相关的解决过程


    2016-05-25 08:58:34

    昨天线上小白系统因为调用外部http接口,超时不释放,导致页面反应很慢,时间一长,报502错误。

    上网查了下,502错误是因为服务对于客户的请求没有得到及时的反应,查询日志,发现很多调http接口异常,页面反应也很慢。

    瞬间想到缩短http客户端调用http接口的超时时间,搜到这个博客http://blog.csdn.net/xinying0424/article/details/36006383  感谢

    HttpClient 4:
    连接超时:
    
    连接超时
    httpclient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT,60000);
    // 或者
    HttpConnectionParams.setConnectionTimeout(params,6000);
    读取超时:
    
    httpclient.getParams().setParameter(CoreConnectionPNames.SO_TIMEOUT,60000);
    // 或者
    HttpConnectionParams.setSoTimeout(params,60000);
    HttpClient 3:
    连接超时:
    httpClient.getHttpConnectionManager().getParams().setConnectionTimeout(60000);
    读取超时:
    httpClient.getHttpConnectionManager().getParams().setSoTimeout(60000);
    

    发现我本来代码里就写了这个,只是时间配置的实在太长

    private static MultiThreadedHttpConnectionManager connectionManager = null;
        private static int connectionTimeOut = 2000;t
        private static int socketTimeOut = 10000;
        private static int maxConnectionPerHost = 20;
        private static int maxTotalConnections = 20;
        private static HttpClient client;
    
        static {
            connectionManager = new MultiThreadedHttpConnectionManager();
            connectionManager.getParams().setConnectionTimeout(connectionTimeOut);
            connectionManager.getParams().setSoTimeout(socketTimeOut);
            connectionManager.getParams().setDefaultMaxConnectionsPerHost(maxConnectionPerHost);
            connectionManager.getParams().setMaxTotalConnections(maxTotalConnections);
            client = new HttpClient(connectionManager);
        }
    

    然后我把socketTimeOut调整为2000,本地想测试下,结果。。。

    java.lang.IllegalArgumentException: host parameter is null  调用接口报错

    查了下 http://wang371134086.iteye.com/blog/1688458  竟然调用http接口没写http://,加上这段解决

    问题解决记录下,感谢一下博客。

    http://blog.csdn.net/xinying0424/article/details/36006383
    http://wang371134086.iteye.com/blog/1688458

    http://blog.sina.com.cn/s/blog_a577563c01013tlz.html

    http://jinnianshilongnian.iteye.com/blog/2089792

    http://www.zhihu.com/question/21647204

  • 相关阅读:
    寒假第七天
    寒假第六天
    寒假第五天
    寒假第四天
    leetcode 105 从前序与中序遍历序列构造二叉树
    leetcode 268 丢失的数字
    leetcode 141 环形链表
    判断顶点是否在三角形内部
    java 基本数据类型
    leetcode 20 有效的括号
  • 原文地址:https://www.cnblogs.com/360buy-gazi/p/5525774.html
Copyright © 2020-2023  润新知