Project: 	
  | View Issue Details[ Jump to Notes ] | [ Issue History ] [ Print ] | |||||||
| ID | ||||||||
| 0036573 | ||||||||
| Type | Category | Severity | Reproducibility | Date Submitted | Last Update | |||
| defect | [Openbravo ERP] Y. DBSourceManager | major | random | 2017-08-02 10:03 | 2017-09-21 16:49 | |||
| Reporter | alostale | View Status | public | |||||
| Assigned To | alostale | |||||||
| Priority | immediate | Resolution | fixed | Fixed in Version | 3.0PR17Q4 | |||
| Status | closed | Fix in branch | Fixed in SCM revision | f258c39df153 | ||||
| Projection | none | ETA | none | Target Version | ||||
| OS | Any | Database | Any | Java version | ||||
| OS Version | Database version | Ant version | ||||||
| Product Version | SCM revision | |||||||
| Merge Request Status | ||||||||
| Review Assigned To | AugustoMauch | |||||||
| OBNetwork customer | No | |||||||
| Web browser | ||||||||
| Modules | Core | |||||||
| Support ticket | ||||||||
| Regression level | QA functional test | |||||||
| Regression date | 2017-05-25 | |||||||
| Regression introduced in release | main | |||||||
| Regression introduced by commit | http://code.openbravo.com/erp/devel/pi/rev/49ac427a0d6689181afa29b95d7384f78eab2dca [^] | |||||||
| Triggers an Emergency Pack | No | |||||||
| Summary | 0036573: import sample data can get stuck when executed by multiple threads | |||||||
| Description | Importing sample data concurrently with several threads can cause locks at JVM level due to usage of non thread safe internal caches. This behavior is unlike to occur, but if it happens, import sample data process lasts forever. | |||||||
| Steps To Reproduce | Within a multi-core run: ant install.source Randomly it can get stuck at importing sample data step. Checking stack traces (jstack): "pool-1-thread-2" prio=10 tid=0x00007fac2c83f800 nid=0x4c3a runnable [0x00007fac2203f000] java.lang.Thread.State: RUNNABLE at java.util.HashMap.getEntry(HashMap.java:465) at java.util.HashMap.get(HashMap.java:417) at org.apache.ddlutils.dynabean.DynaClassCache.getDynaClass(DynaClassCache.java:99) at org.apache.ddlutils.dynabean.DynaClassCache.createNewInstance(DynaClassCache.java:50) at org.apache.ddlutils.model.Database.createDynaBeanFor(Database.java:1342) at org.apache.ddlutils.io.DynaSqlCreateRule.begin(DynaSqlCreateRule.java:61) at org.apache.commons.digester.Digester.startElement(Digester.java:1464) at org.apache.xerces.parsers.AbstractSAXParser.startElement(Unknown Source) at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanStartElement(Unknown Source) at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source) at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source) at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source) at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source) at org.apache.xerces.parsers.XMLParser.parse(Unknown Source) at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source) at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source) at org.apache.commons.digester.Digester.parse(Digester.java:1743) at org.apache.ddlutils.io.DatabaseDataIO.writeDataToDatabase(DatabaseDataIO.java:722) at org.openbravo.ddlutils.task.ImportSampledata$ImportRunner.importXmlFile(ImportSampledata.java:357) at org.openbravo.ddlutils.task.ImportSampledata$ImportRunner.run(ImportSampledata.java:340) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at java.lang.Thread.run(Thread.java:745) "pool-1-thread-1" prio=10 tid=0x00007fac2c83f000 nid=0x4c39 runnable [0x00007fac2213f000] java.lang.Thread.State: RUNNABLE at java.util.HashMap.put(HashMap.java:494) at org.apache.ddlutils.dynabean.DynaClassCache.getDynaClass(DynaClassCache.java:103) at org.apache.ddlutils.dynabean.DynaClassCache.createNewInstance(DynaClassCache.java:50) at org.apache.ddlutils.model.Database.createDynaBeanFor(Database.java:1342) at org.apache.ddlutils.io.DynaSqlCreateRule.begin(DynaSqlCreateRule.java:61) at org.apache.commons.digester.Digester.startElement(Digester.java:1464) at org.apache.xerces.parsers.AbstractSAXParser.startElement(Unknown Source) at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanStartElement(Unknown Source) at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source) at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source) at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source) at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source) at org.apache.xerces.parsers.XMLParser.parse(Unknown Source) at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source) at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source) at org.apache.commons.digester.Digester.parse(Digester.java:1743) at org.apache.ddlutils.io.DatabaseDataIO.writeDataToDatabase(DatabaseDataIO.java:722) at org.openbravo.ddlutils.task.ImportSampledata$ImportRunner.importXmlFile(ImportSampledata.java:357) at org.openbravo.ddlutils.task.ImportSampledata$ImportRunner.run(ImportSampledata.java:340) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at java.lang.Thread.run(Thread.java:745) Both threads are manipulating the same HashMap concurrently causing, in some cases, infinite loop. | |||||||
| Tags | No tags attached. | |||||||
| Attached Files | ||||||||
|  Relationships		[ Relation Graph ] 
		[ Dependency Graph ] | ||||||||||||||||||||||
| 
 | ||||||||||||||||||||||
|  Notes | |
| (0098322) hgbot (developer) 2017-08-02 10:30 | Repository: erp/devel/dbsm-main Changeset: 354fa4d03f404fa6feb04ad691153d249429b1cc Author: Asier Lostalé <asier.lostale <at> openbravo.com> Date: Wed Aug 02 10:28:46 2017 +0200 URL: http://code.openbravo.com/erp/devel/dbsm-main/rev/354fa4d03f404fa6feb04ad691153d249429b1cc [^] fixed bug 36573: import sample data can get stuck if executed concurrently It was caused by a concurrent modification/read of cache HashMap in DynaClassCache. As getDynaClass is the only method that reads and modifies this internal cache, the fix is to make it synchronized. Checked also, while importing sample data this is the only place where shared objects are modified. --- M src/org/apache/ddlutils/dynabean/DynaClassCache.java M src/org/openbravo/ddlutils/task/ImportSampledata.java --- | 
| (0098323) hgbot (developer) 2017-08-02 10:31 | Repository: erp/devel/pi Changeset: f258c39df153c6203cda0f84fb26add44b0ec5b0 Author: Asier Lostalé <asier.lostale <at> openbravo.com> Date: Wed Aug 02 10:30:22 2017 +0200 URL: http://code.openbravo.com/erp/devel/pi/rev/f258c39df153c6203cda0f84fb26add44b0ec5b0 [^] fixed bug 36573: import sample data can get stuck if executed concurrently It was caused by a concurrent modification/read of cache HashMap in DynaClassCache. As getDynaClass is the only method that reads and modifies this internal cache, the fix is to make it synchronized. Checked also, while importing sample data this is the only place where shared objects are modified. --- M src-db/database/lib/dbsourcemanager.jar --- | 
| (0098362) AugustoMauch (administrator) 2017-08-03 11:35 | Code reviewed and verified in pi@f258c39df153 | 
| (0099290) hudsonbot (viewer) 2017-09-21 16:49 | A changeset related to this issue has been promoted main and to the Central Repository, after passing a series of tests. Promotion changeset: https://code.openbravo.com/erp/devel/main/rev/9750b78d3e5c [^] Maturity status: Test | 
|  Issue History | |||
| Date Modified | Username | Field | Change | 
| 2017-08-02 10:03 | alostale | New Issue | |
| 2017-08-02 10:03 | alostale | Assigned To | => alostale | 
| 2017-08-02 10:03 | alostale | OBNetwork customer | => No | 
| 2017-08-02 10:03 | alostale | Modules | => Core | 
| 2017-08-02 10:03 | alostale | Regression level | => QA functional test | 
| 2017-08-02 10:03 | alostale | Regression date | => 2017-05-25 | 
| 2017-08-02 10:03 | alostale | Regression introduced in release | => main | 
| 2017-08-02 10:03 | alostale | Regression introduced by commit | => http://code.openbravo.com/erp/devel/pi/rev/49ac427a0d6689181afa29b95d7384f78eab2dca [^] | 
| 2017-08-02 10:03 | alostale | Triggers an Emergency Pack | => No | 
| 2017-08-02 10:03 | alostale | Relationship added | caused by 0035832 | 
| 2017-08-02 10:04 | alostale | Priority | normal => immediate | 
| 2017-08-02 10:04 | alostale | Relationship added | blocks 0034664 | 
| 2017-08-02 10:05 | alostale | Status | new => scheduled | 
| 2017-08-02 10:30 | hgbot | Checkin | |
| 2017-08-02 10:30 | hgbot | Note Added: 0098322 | |
| 2017-08-02 10:30 | hgbot | Status | scheduled => resolved | 
| 2017-08-02 10:30 | hgbot | Resolution | open => fixed | 
| 2017-08-02 10:30 | hgbot | Fixed in SCM revision | => http://code.openbravo.com/erp/devel/dbsm-main/rev/354fa4d03f404fa6feb04ad691153d249429b1cc [^] | 
| 2017-08-02 10:31 | hgbot | Checkin | |
| 2017-08-02 10:31 | hgbot | Note Added: 0098323 | |
| 2017-08-02 10:31 | hgbot | Fixed in SCM revision | http://code.openbravo.com/erp/devel/dbsm-main/rev/354fa4d03f404fa6feb04ad691153d249429b1cc [^] => http://code.openbravo.com/erp/devel/pi/rev/f258c39df153c6203cda0f84fb26add44b0ec5b0 [^] | 
| 2017-08-02 10:32 | alostale | Review Assigned To | => AugustoMauch | 
| 2017-08-03 11:35 | AugustoMauch | Note Added: 0098362 | |
| 2017-08-03 11:35 | AugustoMauch | Status | resolved => closed | 
| 2017-08-03 11:35 | AugustoMauch | Fixed in Version | => 3.0PR17Q4 | 
| 2017-09-21 16:49 | hudsonbot | Checkin | |
| 2017-09-21 16:49 | hudsonbot | Note Added: 0099290 | |
| Copyright © 2000 - 2009 MantisBT Group |