422723 - Dispatch failed callbacks to avoid blocking selector
This commit is contained in:
parent
b6c0fe2cd6
commit
1b30b0f9a8
|
@ -538,12 +538,12 @@ public abstract class AbstractConnection implements Connection
|
||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
while(true)
|
while(true)
|
||||||
{
|
{
|
||||||
State state=_state.get();
|
State state=_state.get();
|
||||||
if (next(state,state.onFailed()))
|
if (next(state,state.onFailed()))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
onFillInterestedFailed(x);
|
onFillInterestedFailed(x);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -37,6 +37,7 @@ import org.eclipse.jetty.io.EndPoint;
|
||||||
import org.eclipse.jetty.io.EofException;
|
import org.eclipse.jetty.io.EofException;
|
||||||
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.IteratingCallback;
|
||||||
import org.eclipse.jetty.util.IteratingNestedCallback;
|
import org.eclipse.jetty.util.IteratingNestedCallback;
|
||||||
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;
|
||||||
|
@ -466,19 +467,20 @@ public class HttpConnection extends AbstractConnection implements Runnable, Http
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class CommitCallback extends IteratingNestedCallback
|
private class CommitCallback extends IteratingCallback
|
||||||
{
|
{
|
||||||
final ByteBuffer _content;
|
final ByteBuffer _content;
|
||||||
final boolean _lastContent;
|
final boolean _lastContent;
|
||||||
final ResponseInfo _info;
|
final ResponseInfo _info;
|
||||||
|
final Callback _callback;
|
||||||
ByteBuffer _header;
|
ByteBuffer _header;
|
||||||
|
|
||||||
CommitCallback(ResponseInfo info, ByteBuffer content, boolean last, Callback callback)
|
CommitCallback(ResponseInfo info, ByteBuffer content, boolean last, Callback callback)
|
||||||
{
|
{
|
||||||
super(callback);
|
|
||||||
_info=info;
|
_info=info;
|
||||||
_content=content;
|
_content=content;
|
||||||
_lastContent=last;
|
_lastContent=last;
|
||||||
|
_callback=callback;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -586,18 +588,39 @@ public class HttpConnection extends AbstractConnection implements Runnable, Http
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void completed()
|
||||||
|
{
|
||||||
|
_callback.succeeded();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void failed(final Throwable x)
|
||||||
|
{
|
||||||
|
super.failed(x);
|
||||||
|
getExecutor().execute(new Runnable()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
_callback.failed(x);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class ContentCallback extends IteratingNestedCallback
|
private class ContentCallback extends IteratingCallback
|
||||||
{
|
{
|
||||||
final ByteBuffer _content;
|
final ByteBuffer _content;
|
||||||
final boolean _lastContent;
|
final boolean _lastContent;
|
||||||
|
final Callback _callback;
|
||||||
|
|
||||||
ContentCallback(ByteBuffer content, boolean last, Callback callback)
|
ContentCallback(ByteBuffer content, boolean last, Callback callback)
|
||||||
{
|
{
|
||||||
super(callback);
|
|
||||||
_content=content;
|
_content=content;
|
||||||
_lastContent=last;
|
_lastContent=last;
|
||||||
|
_callback=callback;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -668,6 +691,26 @@ public class HttpConnection extends AbstractConnection implements Runnable, Http
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void completed()
|
||||||
|
{
|
||||||
|
_callback.succeeded();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void failed(final Throwable x)
|
||||||
|
{
|
||||||
|
super.failed(x);
|
||||||
|
getExecutor().execute(new Runnable()
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
_callback.failed(x);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue