Java HTTP请求因EOFEException失败

Java HTTP请求因EOFEException失败,java,networking,jetty,Java,Networking,Jetty,使用Jetty 9.4.10.v20180503,我的HTTP客户端偶尔会出现以下错误 java.io.EOFException: HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERM

使用Jetty 9.4.10.v20180503,我的HTTP客户端偶尔会出现以下错误

java.io.EOFException: HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERMINATED/null@null res=PENDING/null@null)[send=HttpSenderOverHTTP@4b7f345a(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]<-DecryptedEndPoint@193ff18c{api.kucoin.com/13.113.121.24:443<->/192.168.1.100:27497,OPEN,fill=-,flush=-,to=22604/0}->HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERMINATED/null@null res=PENDING/null@null)[send=HttpSenderOverHTTP@4b7f345a(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]->SocketChannelEndPoint@2b50cb15{api.kucoin.com/13.113.121.24:443<->/192.168.1.100:27497,ISHUT,fill=-,flush=-,to=21603/0}{io=0/0,kio=0,kro=1}->SslConnection@6de1ad97{NEED_WRAP,eio=-1/-1,di=-1}=>HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERMINATED/null@null res=PENDING/null@null)[send=HttpSenderOverHTTP@4b7f345a(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]
        at java.util.concurrent.CompletableFuture.encodeRelay(CompletableFuture.java:326)
        at java.util.concurrent.CompletableFuture.completeRelay(CompletableFuture.java:338)
        at java.util.concurrent.CompletableFuture.uniRelay(CompletableFuture.java:911)
        at java.util.concurrent.CompletableFuture$UniRelay.tryFire(CompletableFuture.java:899)
        at java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:474)
        at java.util.concurrent.CompletableFuture.completeExceptionally(CompletableFuture.java:1977)
        at com.myapplication.ResponseListener.onComplete(ResponseListener.java:45)
        at org.eclipse.jetty.client.ResponseNotifier.notifyComplete(ResponseNotifier.java:193)
        at org.eclipse.jetty.client.ResponseNotifier.notifyComplete(ResponseNotifier.java:185)
        at org.eclipse.jetty.client.HttpReceiver.terminateResponse(HttpReceiver.java:464)
        at org.eclipse.jetty.client.HttpReceiver.abort(HttpReceiver.java:545)
        at org.eclipse.jetty.client.HttpReceiver.responseFailure(HttpReceiver.java:436)
        at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.failAndClose(HttpReceiverOverHTTP.java:369)
        at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.earlyEOF(HttpReceiverOverHTTP.java:338)
        at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:1476)
        at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.shutdown(HttpReceiverOverHTTP.java:209)
        at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.process(HttpReceiverOverHTTP.java:147)
        at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.receive(HttpReceiverOverHTTP.java:73)
        at org.eclipse.jetty.client.http.HttpChannelOverHTTP.receive(HttpChannelOverHTTP.java:133)
        at org.eclipse.jetty.client.http.HttpConnectionOverHTTP.onFillable(HttpConnectionOverHTTP.java:155)
        at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:281)
        at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:102)
        at org.eclipse.jetty.io.ssl.SslConnection.onFillable(SslConnection.java:291)
        at org.eclipse.jetty.io.ssl.SslConnection$3.succeeded(SslConnection.java:151)
        at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:102)
        at org.eclipse.jetty.io.ChannelEndPoint$2.run(ChannelEndPoint.java:118)
        at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.runTask(EatWhatYouKill.java:333)
        at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.doProduce(EatWhatYouKill.java:310)
        at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.tryProduce(EatWhatYouKill.java:168)
        at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.run(EatWhatYouKill.java:126)
        at org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:366)
        at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:760)
        at org.eclipse.jetty.util.thread.QueuedThreadPool$2.run(QueuedThreadPool.java:678)
        ... 1 common frames omitted
    Caused by: java.io.EOFException: HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERMINATED/null@null res=PENDING/null@null)[send=HttpSenderOverHTTP@4b7f345a(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]<-DecryptedEndPoint@193ff18c{api.kucoin.com/13.113.121.24:443<->/192.168.1.100:27497,OPEN,fill=-,flush=-,to=22604/0}->HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERMINATED/null@null res=PENDING/null@null)[send=HttpSenderOverHTTP@4b7f345a(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]->SocketChannelEndPoint@2b50cb15{api.kucoin.com/13.113.121.24:443<->/192.168.1.100:27497,ISHUT,fill=-,flush=-,to=21603/0}{io=0/0,kio=0,kro=1}->SslConnection@6de1ad97{NEED_WRAP,eio=-1/-1,di=-1}=>HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 <-> r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(exchange=HttpExchange@e7dbbf1 req=TERMINATED/null@null res=PENDING/null@null)[send=HttpSenderOverHTTP@4b7f345a(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]
java.io.EOFException:HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(交换=HttpExchange@e7dbbf1req=终止/null@nullres=待定/null@null)[发送=HttpSenderOverHTTP@4b7f345a(请求=排队,snd=完成,失败=空)[HttpGenerator@61d4e46c{s=开始}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0/1}]HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(交换=HttpExchange@e7dbbf1req=终止/null@nullres=待定/null@null)[发送=HttpSenderOverHTTP@4b7f345a(请求=排队,snd=完成,失败=空)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0/1}]->SocketChannelEndPoint@2b50cb15{api.kucoin.com/13.113.121.24:443/192.168.1.100:27497,ISHUT,fill=-,flush=-,to=21603/0}{io=0/0,kio=0,kro=1}->SslConnection@6de1ad97{NEED_WRAP,eio=-1/-1,di=-1}=>HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(交换=HttpExchange@e7dbbf1req=终止/null@nullres=待定/null@null)[发送=HttpSenderOverHTTP@4b7f345a(请求=排队,snd=完成,失败=空)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0/1}]
位于java.util.concurrent.CompletableFuture.encodeRelay(CompletableFuture.java:326)
位于java.util.concurrent.CompletableFuture.completeRelay(CompletableFuture.java:338)
位于java.util.concurrent.CompletableFuture.uniRelay(CompletableFuture.java:911)
位于java.util.concurrent.CompletableFuture$UniRelay.tryFire(CompletableFuture.java:899)
位于java.util.concurrent.CompletableFuture.postComplete(CompletableFuture.java:474)
在java.util.concurrent.CompletableFuture.CompleteException(CompletableFuture.java:1977)中
位于com.myapplication.ResponseListener.onComplete(ResponseListener.java:45)
位于org.eclipse.jetty.client.responseNotifyComplete(responseNotifyer.java:193)
位于org.eclipse.jetty.client.responseNotifyComplete(responseNotifyer.java:185)
在org.eclipse.jetty.client.HttpReceiver.terminateResponse(HttpReceiver.java:464)
位于org.eclipse.jetty.client.HttpReceiver.abort(HttpReceiver.java:545)
位于org.eclipse.jetty.client.HttpReceiver.responseFailure(HttpReceiver.java:436)
位于org.eclipse.jetty.client.http.HttpReceiverOverHTTP.failAndClose(HttpReceiverOverHTTP.java:369)
位于org.eclipse.jetty.client.http.HttpReceiverOverHTTP.earlyEOF(HttpReceiverOverHTTP.java:338)
http.HttpParser.parseNext(HttpParser.java:1476)
位于org.eclipse.jetty.client.http.HttpReceiverOverHTTP.shutdown(HttpReceiverOverHTTP.java:209)
位于org.eclipse.jetty.client.http.HttpReceiverOverHTTP.process(HttpReceiverOverHTTP.java:147)
位于org.eclipse.jetty.client.http.HttpReceiverOverHTTP.receive(HttpReceiverOverHTTP.java:73)
位于org.eclipse.jetty.client.http.HttpChannelOverHTTP.receive(HttpChannelOverHTTP.java:133)
位于org.eclipse.jetty.client.http.HttpConnectionOverHTTP.onFillable(HttpConnectionOverHTTP.java:155)
位于org.eclipse.jetty.io.AbstractConnection$ReadCallback.successed(AbstractConnection.java:281)
位于org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:102)
位于org.eclipse.jetty.io.ssl.SslConnection.onFillable(SslConnection.java:291)
位于org.eclipse.jetty.io.ssl.SslConnection$3.successed(SslConnection.java:151)
位于org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:102)
位于org.eclipse.jetty.io.ChannelEndPoint$2.run(ChannelEndPoint.java:118)
位于org.eclipse.jetty.util.thread.strategy.eatwatyoukill.runTask(eatwatyoukill.java:333)
位于org.eclipse.jetty.util.thread.strategy.eatwatyoukill.doProduce(eatwatyoukill.java:310)
位于org.eclipse.jetty.util.thread.strategy.eatwatyoukill.tryProduce(eatwatyoukill.java:168)
位于org.eclipse.jetty.util.thread.strategy.eatwatyoukill.run(eatwatyoukill.java:126)
位于org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:366)
位于org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:760)
位于org.eclipse.jetty.util.thread.QueuedThreadPool$2.run(QueuedThreadPool.java:678)
…省略了1个公共帧
原因:java.io.EOFException:HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(交换=HttpExchange@e7dbbf1req=终止/null@nullres=待定/null@null)[发送=HttpSenderOverHTTP@4b7f345a(请求=排队,snd=完成,失败=空)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0/1}]HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(交换=HttpExchange@e7dbbf1req=终止/null@nullres=待定/null@null)[发送=HttpSenderOverHTTP@4b7f345a(请求=排队,snd=完成,失败=空)[HttpGenerator@61d4e46c{s=START}],recv=HttpReceiverOverHTTP@7a7e7f01(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0/1}]->SocketChannelEndPoint@2b50cb15{api.kucoin.com/13.113.121.24:443/192.168.1.100:27497,ISHUT,fill=-,flush=-,to=21603/0}{io=0/0,kio=0,kro=1}->SslConnection@6de1ad97{NEED_WRAP,eio=-1/-1,di=-1}=>HttpConnectionOverHTTP@571103e6(l:/192.168.1.100:27497 r:api.kucoin.com/13.113.121.24:443,closed=false)=>HttpChannelOverHTTP@a423e61(交换=HttpExchange@e7dbbf1req=终止/null@nullres=待定/null@null)[发送=HttpSenderOverHTTP@4b7f345a(req=排队,snd=完成,failu