Commit ce179b9a authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Attempt s2s connections for the same domain every 5 seconds when packets are queued. JM-1422

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@10647 b35dd754-fafc-0310-a699-88a17e54d16e
parent ca6f8652
...@@ -178,6 +178,15 @@ public class OutgoingSessionPromise implements RoutableChannelHandler { ...@@ -178,6 +178,15 @@ public class OutgoingSessionPromise implements RoutableChannelHandler {
private OutgoingSessionPromise promise; private OutgoingSessionPromise promise;
private String domain; private String domain;
private Queue<Packet> packetQueue = new ConcurrentLinkedQueue<Packet>(); private Queue<Packet> packetQueue = new ConcurrentLinkedQueue<Packet>();
/**
* Keep track of the last time s2s failed. Once a packet failed to be sent to a
* remote server this stamp will be used so that for the next 5 seconds future packets
* for the same domain will automatically fail. After 5 seconds a new attempt to
* establish a s2s connection and deliver pendings packets will be performed.
* This optimization is good when the server is receiving many packets per second for the
* same domain. This will help reduce high CPU consumption.
*/
private long failureTimestamp = -1;
public PacketsProcessor(OutgoingSessionPromise promise, String domain) { public PacketsProcessor(OutgoingSessionPromise promise, String domain) {
this.promise = promise; this.promise = promise;
...@@ -188,6 +197,21 @@ public class OutgoingSessionPromise implements RoutableChannelHandler { ...@@ -188,6 +197,21 @@ public class OutgoingSessionPromise implements RoutableChannelHandler {
while (!isDone()) { while (!isDone()) {
Packet packet = packetQueue.poll(); Packet packet = packetQueue.poll();
if (packet != null) { if (packet != null) {
// Check if s2s already failed
if (failureTimestamp > 0) {
// Check if enough time has passed to attempt a new s2s
if (System.currentTimeMillis() - failureTimestamp < 5000) {
returnErrorToSender(packet);
Log.debug(
"OutgoingSessionPromise: Error sending packet to remote server (fast discard): " +
packet);
continue;
}
else {
// Reset timestamp of last failure since we are ready to try again doing a s2s
failureTimestamp = -1;
}
}
try { try {
sendPacket(packet); sendPacket(packet);
} }
...@@ -196,6 +220,8 @@ public class OutgoingSessionPromise implements RoutableChannelHandler { ...@@ -196,6 +220,8 @@ public class OutgoingSessionPromise implements RoutableChannelHandler {
Log.debug( Log.debug(
"OutgoingSessionPromise: Error sending packet to remote server: " + packet, "OutgoingSessionPromise: Error sending packet to remote server: " + packet,
e); e);
// Mark the time when s2s failed
failureTimestamp = System.currentTimeMillis();
} }
} }
} }
......
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