Commit 7fb15f23 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Improved shutdown (not there yet)

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@8516 b35dd754-fafc-0310-a699-88a17e54d16e
parent e30e2b29
...@@ -135,7 +135,7 @@ public class ClusterManager { ...@@ -135,7 +135,7 @@ public class ClusterManager {
events.put(event); events.put(event);
if (!asynchronous) { if (!asynchronous) {
while (!event.isProcessed()) { while (!event.isProcessed()) {
Thread.sleep(100); Thread.sleep(50);
} }
} }
} catch (InterruptedException e) { } catch (InterruptedException e) {
...@@ -171,12 +171,20 @@ public class ClusterManager { ...@@ -171,12 +171,20 @@ public class ClusterManager {
* This also includes the case where this JVM was the senior cluster member and when the islands * This also includes the case where this JVM was the senior cluster member and when the islands
* met again then this JVM stopped being the senior member.<p> * met again then this JVM stopped being the senior member.<p>
* <p/> * <p/>
* This event will be triggered in another thread. This will avoid potential deadlocks * This event could be triggered in another thread. This will avoid potential deadlocks
* in Coherence. * in Coherence.
*
* @param asynchronous true if event will be triggered in background
*/ */
public static void fireLeftCluster() { public static void fireLeftCluster(boolean asynchronous) {
try { try {
events.put(new Event(EventType.left_cluster, null)); Event event = new Event(EventType.left_cluster, null);
events.put(event);
if (!asynchronous) {
while (!event.isProcessed()) {
Thread.sleep(50);
}
}
} catch (InterruptedException e) { } catch (InterruptedException e) {
// Should never happen // Should never happen
} }
...@@ -191,7 +199,7 @@ public class ClusterManager { ...@@ -191,7 +199,7 @@ public class ClusterManager {
* island will have its own senior cluster member. However, when the islands meet again there * island will have its own senior cluster member. However, when the islands meet again there
* could only be one senior cluster member so one of the senior cluster members will stop playing * could only be one senior cluster member so one of the senior cluster members will stop playing
* that role. When that happens the JVM no longer playing that role will receive the * that role. When that happens the JVM no longer playing that role will receive the
* {@link #fireLeftCluster()} and {@link #fireJoinedCluster(byte[],boolean)} events.<p> * {@link #fireLeftCluster(boolean)} and {@link #fireJoinedCluster(byte[],boolean)} events.<p>
* <p/> * <p/>
* This event will be triggered in another thread. This will avoid potential deadlocks * This event will be triggered in another thread. This will avoid potential deadlocks
* in Coherence. * in Coherence.
......
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