summaryrefslogtreecommitdiffstats
path: root/jdisc_core
diff options
context:
space:
mode:
authorBjørn Christian Seime <bjorncs@oath.com>2017-08-23 14:30:01 +0200
committerBjørn Christian Seime <bjorncs@oath.com>2017-08-23 14:41:08 +0200
commit38c0f37f802ae99b459ee88dc2e1174e25815685 (patch)
tree41c675110c469592ef1e670b94c4dae39e3695f4 /jdisc_core
parentc9714fd5f0da37b73c075b81da8fe55c007afcc8 (diff)
Perform best-effort cleanup to stop JDisc from never closing connection
Diffstat (limited to 'jdisc_core')
-rw-r--r--jdisc_core/src/main/java/com/yahoo/jdisc/handler/ThreadedRequestHandler.java28
1 files changed, 23 insertions, 5 deletions
diff --git a/jdisc_core/src/main/java/com/yahoo/jdisc/handler/ThreadedRequestHandler.java b/jdisc_core/src/main/java/com/yahoo/jdisc/handler/ThreadedRequestHandler.java
index 3351beb99be..d794b2345ab 100644
--- a/jdisc_core/src/main/java/com/yahoo/jdisc/handler/ThreadedRequestHandler.java
+++ b/jdisc_core/src/main/java/com/yahoo/jdisc/handler/ThreadedRequestHandler.java
@@ -95,7 +95,12 @@ public abstract class ThreadedRequestHandler extends AbstractRequestHandler {
protected void handleRequest(Request request, BufferedContentChannel requestContent,
ResponseHandler responseHandler)
{
- handleRequest(request, requestContent.toReadable(), responseHandler);
+ ReadableContentChannel readable = requestContent.toReadable();
+ try {
+ handleRequest(request, readable, responseHandler);
+ } finally {
+ while (readable.read() != null) {} // consume all ignored content
+ }
}
/**
@@ -110,7 +115,12 @@ public abstract class ThreadedRequestHandler extends AbstractRequestHandler {
protected void handleRequest(Request request, ReadableContentChannel requestContent,
ResponseHandler responseHandler)
{
- handleRequest(request, requestContent.toStream(), responseHandler);
+ ContentInputStream inputStream = requestContent.toStream();
+ try {
+ handleRequest(request, inputStream, responseHandler);
+ } finally {
+ while (inputStream.read() >= 0) {} // consume all ignored content
+ }
}
/**
@@ -126,9 +136,6 @@ public abstract class ThreadedRequestHandler extends AbstractRequestHandler {
protected void handleRequest(Request request, ContentInputStream requestContent,
ResponseHandler responseHandler)
{
- while (requestContent.read() >= 0) {
- // drain content stream
- }
ResponseDispatch.newInstance(Response.Status.NOT_IMPLEMENTED).dispatch(responseHandler);
}
@@ -150,7 +157,18 @@ public abstract class ThreadedRequestHandler extends AbstractRequestHandler {
public void run() {
try (final ResourceReference ref = requestReference) {
ThreadedRequestHandler.this.handleRequest(request, content, responseHandler);
+ consumeRequestContent();
}
}
+
+ private void consumeRequestContent() {
+ if (content.isConnected()) return;
+ try {
+ ReadableContentChannel requestContent = content.toReadable();
+ while (requestContent.read() != null) {
+ // consume all ignored content
+ }
+ } catch (IllegalStateException ignored) {}
+ }
}
}