Issue #295 Ensure Jetty Client use of Inflater calls .end() to avoid memory leak

Signed-off-by: Sergiu Prodan <p.sergiu92@gmail.com>
This commit is contained in:
Sergiu Prodan 2016-10-06 17:10:37 +03:00 committed by Simone Bordet
parent 863913b64e
commit 407111a796
2 changed files with 19 additions and 1 deletions

View File

@ -25,11 +25,12 @@ import java.util.zip.Inflater;
import java.util.zip.ZipException; import java.util.zip.ZipException;
import org.eclipse.jetty.util.BufferUtil; import org.eclipse.jetty.util.BufferUtil;
import org.eclipse.jetty.util.component.Destroyable;
/** /**
* {@link ContentDecoder} for the "gzip" encoding. * {@link ContentDecoder} for the "gzip" encoding.
*/ */
public class GZIPContentDecoder implements ContentDecoder public class GZIPContentDecoder implements ContentDecoder, Destroyable
{ {
private final Inflater inflater = new Inflater(true); private final Inflater inflater = new Inflater(true);
private final byte[] bytes; private final byte[] bytes;
@ -322,6 +323,12 @@ public class GZIPContentDecoder implements ContentDecoder
flags = 0; flags = 0;
} }
@Override
public void destroy()
{
inflater.end();
}
protected boolean isFinished() protected boolean isFinished()
{ {
return state == State.INITIAL; return state == State.INITIAL;

View File

@ -37,6 +37,7 @@ import org.eclipse.jetty.http.HttpStatus;
import org.eclipse.jetty.util.BufferUtil; import org.eclipse.jetty.util.BufferUtil;
import org.eclipse.jetty.util.Callback; import org.eclipse.jetty.util.Callback;
import org.eclipse.jetty.util.CountingCallback; import org.eclipse.jetty.util.CountingCallback;
import org.eclipse.jetty.util.component.Destroyable;
import org.eclipse.jetty.util.log.Log; import org.eclipse.jetty.util.log.Log;
import org.eclipse.jetty.util.log.Logger; import org.eclipse.jetty.util.log.Logger;
@ -469,6 +470,7 @@ public abstract class HttpReceiver
*/ */
protected void reset() protected void reset()
{ {
destroyDecoder(decoder);
decoder = null; decoder = null;
} }
@ -481,9 +483,18 @@ public abstract class HttpReceiver
*/ */
protected void dispose() protected void dispose()
{ {
destroyDecoder(decoder);
decoder = null; decoder = null;
} }
private static void destroyDecoder(ContentDecoder decoder)
{
if (decoder instanceof Destroyable)
{
((Destroyable)decoder).destroy();
}
}
public boolean abort(HttpExchange exchange, Throwable failure) public boolean abort(HttpExchange exchange, Throwable failure)
{ {
// Update the state to avoid more response processing. // Update the state to avoid more response processing.