[
https://jira.jboss.org/jira/browse/JBAS-7788?page=com.atlassian.jira.plug...
]
Adrian Brock commented on JBAS-7788:
------------------------------------
The semantic requested is broken behaviour unless you are using auto-commit=true.
This is like setting the auto reconnect option for MySQL when using it JTA transactions,
it is wrong.
See for example this FAQ:
http://community.jboss.org/wiki/RetryingTransactions
Once you are in a transaction, any resource failure requires you to retry the transaction
from the start,
you can't just muddle on because you don't know how the resource has changed if
you have made calls to it.
It will fail at commit anyway, if the broken resource has been enlisted in the
TransactionManager.
It won't be able to prepare() it.
<check-valid-connection-sql> done after a failure maybe?
--------------------------------------------------------
Key: JBAS-7788
URL:
https://jira.jboss.org/jira/browse/JBAS-7788
Project: JBoss Application Server
Issue Type: Feature Request
Security Level: Public(Everyone can see)
Components: EJB3, Hibernate service
Affects Versions: JBossAS-5.1.0.GA
Reporter: deanhiller
Assignee: Carlo de Wolf
Priority: Critical
related directly to this bug in seam
https://jira.jboss.org/jira/browse/JBSEAM-4528
I would prefer the <check-valid-connection-sql> be run AFTER any exceptions from
the jdbc api rather than before it. This would fix half the bug in the ticket referred to
above(at least with postgres' case)....
ie.
1. go get a wrapper connection(not from pool)
2. when you make a real jdbc call, go get the real connection from the pool
3. if that jdbc call fails with an exception, run the check-valid-connection-sql
4. If check-valid-connection-sql fails, go get another connection from pool(or create
one) and if fails, move to next
5. once all connections are exhausted, throw exception back to framework or whoever
called the jdbc call.
NOTE: This gives the performance benefit on sunny day we are never running the check
valid connection sql. It also solves half of the ticket above which tends to break
postgres/jboss/seam combination from working. I have to have check valid connection sql
or my seam app never recovers from a db outage but having that also causes all normal seam
pages that don't need the database to spin the browser into infinite redirect(ie. if I
hit login page it comes up in jboss/seam IF AND ONLY IF I don't have
check-valid-connection-sql set).
thanks,
Dean
--
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