[jboss-jira] [JBoss JIRA] Created: (JBRULES-1776) Thread does not release lock on AbstractRuleBase object when an error occurs.
Le Huynh (JIRA)
jira-events at lists.jboss.org
Sun Sep 21 22:12:21 EDT 2008
Thread does not release lock on AbstractRuleBase object when an error occurs.
-----------------------------------------------------------------------------
Key: JBRULES-1776
URL: https://jira.jboss.org/jira/browse/JBRULES-1776
Project: JBoss Drools
Issue Type: Bug
Security Level: Public (Everyone can see)
Affects Versions: 4.0.7
Environment: Windows XP, jdk1.5.0_01
Reporter: Le Huynh
Assignee: Mark Proctor
When modifying the rules using addPackage() or removeRule() from the AbstractRulebase class this would lock() the object. But if any error occurs after the lock() is called, this object's lock is never released as it would never reach the line to call unlock(). It appears that the removePackage() in the AbstractRulebase is the only method that has a try{} finally{} to unlock if there is an error.
Below is stack of removing a rule, when this occurs, all other threads will wait forever when trying to modify rules.
"TP-Processor20" daemon prio=10 tid=0x83adcc00 nid=0x4af5 in Object.wait() [0x82231000..0x82232f30]
java.lang.Thread.State: WAITING (on object monitor)
at java.lang.Object.wait(Native Method)
- waiting on <0x964babb0> (a org.drools.util.concurrent.locks.ReentrantLock$NonfairSync)
at java.lang.Object.wait(Object.java:485)
at org.drools.util.concurrent.locks.ReentrantLock$NonfairSync.lock(ReentrantLock.java:106)
- locked <0x964babb0> (a org.drools.util.concurrent.locks.ReentrantLock$NonfairSync)
at org.drools.util.concurrent.locks.ReentrantLock.lock(ReentrantLock.java:195)
at org.drools.common.AbstractRuleBase.lock(AbstractRuleBase.java:343)
at org.drools.common.AbstractRuleBase.removeRule(AbstractRuleBase.java:630)
- locked <0x964aa710> (a java.util.HashMap)
at com.prototype.rules.RulesEngine.removeRuleFromEngine(RulesEngine.java:207)
at com.prototype.rules.RulesEngine.updateRule(RulesEngine.java:137)
- locked <0x964a6208> (a com.prototype.rules.RulesEngine)
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: https://jira.jboss.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the jboss-jira
mailing list