gpt4 book ai didi

java - EntityUtils.toString() 中的间歇性死锁

转载 作者:塔克拉玛干 更新时间:2023-11-01 19:08:46 24 4
gpt4 key购买 nike

我正在运行带有 HttpClient 4.1.2 的 Java 6。我一直在使用这样的代码来重新加载 Guava 缓存。它在将近一年零一天的时间里运行良好,我的缓存停止可靠地重新加载。

我现在已将问题缩小到 EntityUtils.toString() 期间的死锁,但我不知道为什么会发生或如何避免它。

HttpEntity entity = null;
try {
entity = PooledHttpClient.getHttpEntity(new HttpGet(location));
// PROBLEM HERE: Deadlock occurs rarely in EntityUtils.toString()
final String resource = EntityUtils.toString(entity);
return resource;
} catch (Exception e) {
// Something went wrong, log the error or retry
} finally {
EntityUtils.consume(entity);
}

我加了调试,看到这个方法卡了一次,缓存就停止重新加载了。这是来自线程转储的堆栈跟踪:

"pool-6-thread-172" prio=3 tid=0x0000000017cc4800 nid=0x862 runnable [0xfffffd7fdf1f0000]
java.lang.Thread.State: RUNNABLE
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(SocketInputStream.java:129)
at org.apache.http.impl.io.AbstractSessionInputBuffer.read(AbstractSessionInputBuffer.java:187)
at org.apache.http.impl.io.ContentLengthInputStream.read(ContentLengthInputStream.java:176)
at org.apache.http.conn.EofSensorInputStream.read(EofSensorInputStream.java:138)
at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:264)
at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:306)
at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:158)
- locked <0x0000000735ec3cc0> (a java.io.InputStreamReader)
at java.io.InputStreamReader.read(InputStreamReader.java:167)
at java.io.Reader.read(Reader.java:123)
at org.apache.http.util.EntityUtils.toString(EntityUtils.java:199)
at org.apache.http.util.EntityUtils.toString(EntityUtils.java:221)
at com.something.Resource.getResource(Resource.java:216)
...

有什么想法吗?

最佳答案

我终于弄清楚这里的问题是什么,关键在于堆栈跟踪。回想起来很明显,但当时我不明白。代码基本上卡在 InputStreamReader.read() 处,原因是没有设置套接字超时(至少对我而言)。

我有这样的事情:HttpConnectionParams.setConnectionTimeout(params, 10000);

但是,我错过了套接字的关键第二次超时:HttpConnectionParams.setSoTimeout(params, 30000);

如果没有第二次超时,如果建立连接但之后出现问题,我将无限期地等待。我在这里感到非常困惑,因为有问题的代码在生产环境中运行了一年多,没有出现任何问题,然后有一天我开始每小时或每天遇到问题(从 Heroku 获取文件的一些内容)。仍然不确定为什么会这样,因为我添加了套接字超时,一切都很顺利!

希望对您有所帮助!

关于java - EntityUtils.toString() 中的间歇性死锁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25425551/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com