Openbravo Issue Tracking System - Openbravo ERP
View Issue Details
0058060Openbravo ERPA. Platformpublic2025-02-24 14:272025-02-28 12:07
alostale 
Triage Platform Base 
normalmajorhave not tried
closedfixed 
5
 
PR25Q2 
approved
No
Core
No
0058060: websocket infra: DB transaction remains open
When websockets is enabled, a DB transaction is kept open forever not being returnd to the pool.
1. Activate Websockets: set "Enable Message Client Manager" preference to Y
2. Restart Tomcat
3. Check pg_stat_activity, there is a transaction that is created on Tomcat start and reused to check pending messages every 10s.

select xact_start, state_change, query from pg_stat_activity where state = 'idle in transaction';
          xact_start           |         state_change         |                                                                                                                                                                                                                                                                                                      
query                                                                                                                                                                                                                                                                                                      

-------------------------------+------------------------------+-------------------------------------------------------------------------
 
2025-02-24 14:09:39.901561+01 | 2025-02-24 14:26:19.80062+01 | select this_.C_Persisted_Message_ID as 
c_persis1_278_0_, this_.AD_Client_ID as ad_clien2_278_0_, this_.AD_Org_ID as ad_org_i3_278_0_, this_.Isactive 
as isactive4_278_0_, this_.Created as created5_278_0_, this_.Createdby as createdb6_278_0_, this_.Updated 
as updated7_278_0_, this_.Updatedby as updatedb8_278_0_, this_.Payload as payload9_278_0_, this_.Type 
as type10_278_0_, this_.Expirationdate as expirat11_278_0_, this_.Context as context12_278_0_ from C_Persisted_Message 
this_ where this_.Expirationdate>=$1 and this_.Created>$2 and this_.Isactive=$3 order by this_.Created 
asc limit $4
No tags attached.
depends on backport 0058102PR25Q1 closed Triage Platform Base websocket infra: DB transaction remains open 
depends on backport 0058103PR24Q4.2 closed Triage Platform Base websocket infra: DB transaction remains open 
caused by feature request 0056195 closed cberner New infrastructure for sending messages, using websockets 
Issue History
2025-02-24 14:27alostaleNew Issue
2025-02-24 14:27alostaleAssigned To => Triage Platform Base
2025-02-24 14:27alostaleOBNetwork customer => No
2025-02-24 14:27alostaleModules => Core
2025-02-24 14:27alostaleTriggers an Emergency Pack => No
2025-02-24 14:28alostaleSteps to Reproduce Updatedbug_revision_view_page.php?rev_id=29279#r29279
2025-02-24 14:29alostaleRelationship addedcaused by 0056195
2025-02-24 14:43hgbotMerge Request Status => open
2025-02-24 14:43hgbotNote Added: 0176081
2025-02-27 16:50cbernerStatusnew => scheduled
2025-02-27 16:55hgbotMerge Request Statusopen => approved
2025-02-28 12:07hgbotResolutionopen => fixed
2025-02-28 12:07hgbotStatusscheduled => closed
2025-02-28 12:07hgbotNote Added: 0176283
2025-02-28 12:07hgbotFixed in Version => PR25Q2
2025-02-28 12:07hgbotNote Added: 0176284

Notes
(0176081)
hgbot   
2025-02-24 14:43   
Merge Request created: https://gitlab.com/orisha-group/bu-commerce/openbravo/product/openbravo/-/merge_requests/1552 [^]
(0176283)
hgbot   
2025-02-28 12:07   
Merge request merged: https://gitlab.com/orisha-group/bu-commerce/openbravo/product/openbravo/-/merge_requests/1552 [^]
(0176284)
hgbot   
2025-02-28 12:07   
Directly closing issue as related merge request is already approved.

Repository: https://gitlab.com/orisha-group/bu-commerce/openbravo/product/openbravo [^]
Changeset: 10a81915610ef81a869c64e8394d447a52e1941c
Author: Cristian Berner <cristian.berner@openbravo.com>
Date: 28-02-2025 11:07:19
URL: https://gitlab.com/orisha-group/bu-commerce/openbravo/product/openbravo/-/commit/10a81915610ef81a869c64e8394d447a52e1941c [^]

Fixes ISSUE-58060: websocket infra: DB transaction remains open

Closes transactions on all DatabaseMessageRegistryPersistence methods.
These methods are outside of a DAL controlled Thread and need to be
closed intentionally.

---
M modules/org.openbravo.client.application/src/org/openbravo/client/application/messageclient/DatabaseMessageRegistryPersistence.java
---