[jboss-cvs] JBossAS SVN: r67541 - branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow.
jboss-cvs-commits at lists.jboss.org
jboss-cvs-commits at lists.jboss.org
Wed Nov 28 00:41:43 EST 2007
Author: bdecoste
Date: 2007-11-28 00:41:42 -0500 (Wed, 28 Nov 2007)
New Revision: 67541
Modified:
branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsActivationSpec.java
branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsServerSessionPool.java
Log:
[JBPAPP-456] fix for TIBCO EMS HA session recycle
Modified: branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsActivationSpec.java
===================================================================
--- branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsActivationSpec.java 2007-11-28 05:41:26 UTC (rev 67540)
+++ branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsActivationSpec.java 2007-11-28 05:41:42 UTC (rev 67541)
@@ -122,6 +122,43 @@
private Boolean isSameRMOverrideValue;
+ private boolean forceClearOnShutdown = false;
+
+ private long forceClearOnShutdownInterval = 1000;
+
+ private int forceClearAttempts = 0;
+
+ public void setForceClearOnShutdown(boolean forceClear)
+ {
+ this.forceClearOnShutdown = forceClear;
+ }
+
+ public boolean isForceClearOnShutdown()
+ {
+ return this.forceClearOnShutdown;
+ }
+
+ public long getForceClearOnShutdownInterval()
+ {
+ return this.forceClearOnShutdownInterval;
+ }
+
+ public void setForceClearOnShutdownInterval(long forceClearOnShutdownInterval)
+ {
+ this.forceClearOnShutdownInterval = forceClearOnShutdownInterval;
+ }
+
+ public int getForceClearAttempts()
+ {
+ return forceClearAttempts;
+ }
+
+ public void setForceClearAttempts(int forceClearAttempts)
+ {
+ this.forceClearAttempts = forceClearAttempts;
+ }
+
+
/**
* @return the acknowledgeMode.
*/
Modified: branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsServerSessionPool.java
===================================================================
--- branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsServerSessionPool.java 2007-11-28 05:41:26 UTC (rev 67540)
+++ branches/JBPAPP_4_2/connector/src/main/org/jboss/resource/adapter/jms/inflow/JmsServerSessionPool.java 2007-11-28 05:41:42 UTC (rev 67541)
@@ -222,15 +222,41 @@
sessionCount -= serverSessions.size();
serverSessions.clear();
- // Wait for inuse sessions
- while (sessionCount > 0)
- {
- try
+ if (activation.getActivationSpec().isForceClearOnShutdown())
+ {
+ int attempts = 0;
+ int forceClearAttempts = activation.getActivationSpec().getForceClearAttempts();
+ long forceClearInterval = activation.getActivationSpec().getForceClearOnShutdownInterval();
+
+ log.info("Force clear behavior in effect. Waiting for " + forceClearInterval + " milliseconds for " + forceClearAttempts + " attempts.");
+
+ while((sessionCount > 0) && (attempts < forceClearAttempts))
{
- serverSessions.wait();
+ try
+ {
+ serverSessions.wait(forceClearInterval);
+ log.trace("Clear attempt " + attempts);
+ ++attempts;
+
+ }catch(InterruptedException ignore)
+ {
+
+ }
+
}
- catch (InterruptedException ignore)
+ }
+ else
+ {
+ // Wait for inuse sessions
+ while (sessionCount > 0)
{
+ try
+ {
+ serverSessions.wait();
+ }
+ catch (InterruptedException ignore)
+ {
+ }
}
}
}
More information about the jboss-cvs-commits
mailing list