#5150 - Infinite connection timeout support in ManagedSelector
Signed-off-by: Oleg Mozzhechkov <oleg.mozzhechkov@gmail.com>
This commit is contained in:
parent
1b3cb2ea8d
commit
bffd6a2c0f
|
@ -888,7 +888,11 @@ public class ManagedSelector extends ContainerLifeCycle implements Dumpable
|
||||||
{
|
{
|
||||||
this.channel = channel;
|
this.channel = channel;
|
||||||
this.attachment = attachment;
|
this.attachment = attachment;
|
||||||
this.timeout = ManagedSelector.this._selectorManager.getScheduler().schedule(this, ManagedSelector.this._selectorManager.getConnectTimeout(), TimeUnit.MILLISECONDS);
|
final long timeout = ManagedSelector.this._selectorManager.getConnectTimeout();
|
||||||
|
if (timeout > 0)
|
||||||
|
this.timeout = ManagedSelector.this._selectorManager.getScheduler().schedule(this, timeout, TimeUnit.MILLISECONDS);
|
||||||
|
else
|
||||||
|
this.timeout = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -919,6 +923,7 @@ public class ManagedSelector extends ContainerLifeCycle implements Dumpable
|
||||||
{
|
{
|
||||||
if (failed.compareAndSet(false, true))
|
if (failed.compareAndSet(false, true))
|
||||||
{
|
{
|
||||||
|
if (timeout != null)
|
||||||
timeout.cancel();
|
timeout.cancel();
|
||||||
IO.close(channel);
|
IO.close(channel);
|
||||||
ManagedSelector.this._selectorManager.connectionFailed(channel, failure, attachment);
|
ManagedSelector.this._selectorManager.connectionFailed(channel, failure, attachment);
|
||||||
|
|
Loading…
Reference in New Issue