Commit 9d12881e authored by akrherz's avatar akrherz

OF-929 prevent ghosts by removing ioSession check

Since the release of Openfire 3.9.3, users have reported problems with
"ghost" sessions left on the server. After reviewing the changes that
went into the 3.9.3 release, it seemed the fix for OF-464 may have had
some side effect causing this.

Since Igniterealtime's Openfire was reproducing OF-829, I did a test
whereby the functional changes of Igniterealtime/Openfire#ad08cae9
were reverted.  After 36 hours, there were no ghosts!

This will likely necessitate reopening OF-464.
parent ad2f9200
...@@ -295,10 +295,6 @@ public class NIOConnection implements Connection { ...@@ -295,10 +295,6 @@ public class NIOConnection implements Connection {
IoBuffer buffer = IoBuffer.allocate(4096); IoBuffer buffer = IoBuffer.allocate(4096);
buffer.setAutoExpand(true); buffer.setAutoExpand(true);
try { try {
// OF-464: if the connection has been dropped, fail over to backupDeliverer (offline)
if (!ioSession.isConnected()) {
throw new IOException("Connection reset/closed by peer");
}
buffer.putString(packet.getElement().asXML(), encoder.get()); buffer.putString(packet.getElement().asXML(), encoder.get());
if (flashClient) { if (flashClient) {
buffer.put((byte) '\0'); buffer.put((byte) '\0');
...@@ -344,10 +340,6 @@ public class NIOConnection implements Connection { ...@@ -344,10 +340,6 @@ public class NIOConnection implements Connection {
buffer.flip(); buffer.flip();
ioSessionLock.lock(); ioSessionLock.lock();
try { try {
// OF-464: handle dropped connections (no backupDeliverer in this case?)
if (!ioSession.isConnected()) {
throw new IOException("Connection reset/closed by peer");
}
ioSession.write(buffer); ioSession.write(buffer);
} }
finally { finally {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment