Project: 	
  | View Issue Details[ Jump to Notes ] | [ Issue History ] [ Print ] | |||||||
| ID | ||||||||
| 0037895 | ||||||||
| Type | Category | Severity | Reproducibility | Date Submitted | Last Update | |||
| backport | [Openbravo ERP] A. Platform | minor | have not tried | 2018-02-13 10:16 | 2018-02-13 13:32 | |||
| Reporter | AugustoMauch | View Status | public | |||||
| Assigned To | alostale | |||||||
| Priority | immediate | Resolution | fixed | Fixed in Version | 3.0PR17Q4.1 | |||
| Status | closed | Fix in branch | Fixed in SCM revision | eadd42437276 | ||||
| Projection | none | ETA | none | Target Version | 3.0PR17Q4.1 | |||
| OS | Any | Database | Any | Java version | ||||
| OS Version | Database version | Ant version | ||||||
| Product Version | SCM revision | |||||||
| Merge Request Status | ||||||||
| Review Assigned To | ||||||||
| OBNetwork customer | No | |||||||
| Web browser | ||||||||
| Modules | Core | |||||||
| Support ticket | ||||||||
| Regression level | Production - Confirmed Stable | |||||||
| Regression date | 2016-04-26 | |||||||
| Regression introduced in release | 3.0PR17Q3 | |||||||
| Regression introduced by commit | https://code.openbravo.com/erp/devel/pi/rev/dafb9b081971 [^] | |||||||
| Triggers an Emergency Pack | No | |||||||
| Summary | 0037895: ConcurrentModificationException when working with SessionListener.activeHttpSessions | |||||||
| Description | The following exception has been found in a customer log: b45df575 2018-02-12 16:53:13,566 [ajp-bio-127.0.0.1-8009-exec-54] ERROR org.openbravo.erpCommon.security.SessionListener - Error getting active session from context java.util.ConcurrentModificationException at java.util.HashMap$HashIterator.nextEntry(HashMap.java:923) at java.util.HashMap$KeyIterator.next(HashMap.java:957) at org.openbravo.erpCommon.security.SessionListener.getActiveSession(SessionListener.java:178) at org.openbravo.erpCommon.obps.ActivationKey.shouldDeactivateSession(ActivationKey.java:1175) at org.openbravo.erpCommon.obps.ActivationKey.deactivateTimeOutSessions(ActivationKey.java:1131) at org.openbravo.erpCommon.obps.ActivationKey.checkOPSLimitations(ActivationKey.java:976) at org.openbravo.erpCommon.obps.ActivationKey.checkOPSLimitations(ActivationKey.java:923) The access to the SessionListener.activeHttpSessions Set is not being properly managed, as it is possible to add/remove elements from it while it is being iterated. | |||||||
| Steps To Reproduce | - | |||||||
| Tags | No tags attached. | |||||||
| Attached Files | ||||||||
|  Relationships		[ Relation Graph ] 
		[ Dependency Graph ] | ||||||||
| 
 | ||||||||
|  Notes | |
| (0102353) hgbot (developer) 2018-02-13 12:57 | Repository: erp/backports/3.0PR17Q4.1 Changeset: eadd42437276a775bf4516aa98765ee1d46eff31 Author: Asier Lostalé <asier.lostale <at> openbravo.com> Date: Tue Feb 13 12:06:02 2018 +0100 URL: http://code.openbravo.com/erp/backports/3.0PR17Q4.1/rev/eadd42437276a775bf4516aa98765ee1d46eff31 [^] fixed bug 37895, fixed bug 37901: incorrect CU handling in concurrency and POS Concurrent Users management had two different problems: * If a backoffice session was reused in POS closing backoffice browser, a CU session was counted and it was not deactivated while POS session was active. In this situation, the session should be deactivated if CU limit has been reached. * Code for creating and checking active http sessions in context was not thread safe, so it was possible to get an error when checking if session was active while other sessions were created/destroyed in paralell. This has been fixed by synchronizing on active session set. Having solved previous issue this should not create excessive contentention as it will be executed only if: CU limit has been reached and there are sessions created by mobile modules exclude POS. --- M src/org/openbravo/erpCommon/obps/ActivationKey.java M src/org/openbravo/erpCommon/security/SessionListener.java --- | 
| (0102359) AugustoMauch (administrator) 2018-02-13 13:32 | Code reviewed and verified | 
|  Issue History | |||
| Date Modified | Username | Field | Change | 
| 2018-02-13 10:23 | alostale | Type | defect => backport | 
| 2018-02-13 10:23 | alostale | Target Version | => 3.0PR17Q4.1 | 
| 2018-02-13 12:57 | hgbot | Checkin | |
| 2018-02-13 12:57 | hgbot | Note Added: 0102353 | |
| 2018-02-13 12:57 | hgbot | Status | scheduled => resolved | 
| 2018-02-13 12:57 | hgbot | Resolution | open => fixed | 
| 2018-02-13 12:57 | hgbot | Fixed in SCM revision | => http://code.openbravo.com/erp/backports/3.0PR17Q4.1/rev/eadd42437276a775bf4516aa98765ee1d46eff31 [^] | 
| 2018-02-13 13:32 | AugustoMauch | Note Added: 0102359 | |
| 2018-02-13 13:32 | AugustoMauch | Status | resolved => closed | 
| 2018-02-13 13:32 | AugustoMauch | Fixed in Version | => 3.0PR17Q4.1 | 
| Copyright © 2000 - 2009 MantisBT Group |