Java HttpClient execute 永久阻塞问题

    HttpClient是Java访问http服务常用的包,之前使用一直没有出现什么问题,前几天编写一个爬虫程序代码时,程序启动后执行没有问题,按正常逻辑执行,过了一段时间便会阻塞在httpclient.execute()方法处,后使用RequestConfig设置connectionTimeout,socketTimeout 均无效,附上当时出问题的代码

CloseableHttpClient httpClient = HttpClients.custom().build();
HttpGet httpget = new HttpGet(url);
RequestConfig.Builder builder = RequestConfig.custom();
//此处设置了代理
HttpHost proxy = new HttpHost(ip, port);
builder = builder.setProxy(proxy);
builder.setSocketTimeout(5000).setConnectTimeout(5000).setConnectionRequestTimeout(5000);
RequestConfig config = builder.build();
httpget.setConfig(config);
//下面为出问题时阻塞的代码
response = httpClient.execute(httpget);

编写的代码是单线程,有小概率会阻塞在httpClient.execute(httpget)那一行,且阻塞后永久无法返回,这是非常坑的地方,于是开始排查这个问题,用Jconsole查看进程的执行状态,在问题复现的时候,main进程始终是处于socketRead0的Native 方法上,始终不能返回

<
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值