diff options
| author | Keith Wall <kwall@apache.org> | 2014-12-09 17:36:33 +0000 |
|---|---|---|
| committer | Keith Wall <kwall@apache.org> | 2014-12-09 17:36:33 +0000 |
| commit | 7e31771bc163e945510512066608da03ebfe4e52 (patch) | |
| tree | 804fd2ed93db80cde39f8a68bf790026d859d12b /qpid/java | |
| parent | 2797e4bed9a3480d795023843efeb2f71ba95392 (diff) | |
| download | qpid-python-7e31771bc163e945510512066608da03ebfe4e52.tar.gz | |
Stop reading bytes from the wire once the transport is closed. Also prevent further ByteBuffers being queued to be sent once the transport is closed too
git-svn-id: https://svn.apache.org/repos/asf/qpid/branches/QPID-6262-JavaBrokerNIO@1644128 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java')
| -rw-r--r-- | qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java b/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java index f74f934ff3..a6fc3fa148 100644 --- a/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java +++ b/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java @@ -35,6 +35,7 @@ import org.slf4j.LoggerFactory; import org.apache.qpid.thread.Threading; import org.apache.qpid.transport.Receiver; import org.apache.qpid.transport.Sender; +import org.apache.qpid.transport.SenderClosedException; import org.apache.qpid.transport.SenderException; import org.apache.qpid.transport.network.Ticker; @@ -104,6 +105,10 @@ public class NonBlockingSenderReceiver implements Runnable, Sender<ByteBuffer> @Override public void send(final ByteBuffer msg) { + if (_closed.get()) + { + throw new SenderClosedException("I/O for thread " + _remoteSocketAddress + " is already closed"); + } // append to list and do selector wakeup _buffers.add(msg); _selector.wakeup(); @@ -223,8 +228,8 @@ public class NonBlockingSenderReceiver implements Runnable, Sender<ByteBuffer> private void doRead() throws IOException { - int remaining; - do + int remaining = 0; + while (remaining == 0 && !_closed.get()) { if(_currentBuffer == null || _currentBuffer.remaining() == 0) { @@ -241,7 +246,5 @@ public class NonBlockingSenderReceiver implements Runnable, Sender<ByteBuffer> _currentBuffer = _currentBuffer.slice(); _receiver.received(dup); } - while (remaining == 0); - } } |
