Uploaded image for project: 'MariaDB Connector/J'
  1. MariaDB Connector/J
  2. CONJ-1189

Resume for XID raised -5: invalid arguments were given for the XA operation

Details

    • Bug
    • Status: Closed (View Workflow)
    • Major
    • Resolution: Fixed
    • 3.3.3
    • 3.4.1
    • XA
    • None
    • OS: Unix based
      JVM: 17.0.9
      External Java libraries: Spring Boot 3.3.1, Atomikos 6.0.0, Hibernate 6.5.2.Final

    Description

      Hi,

      our system depends of two different MariaDB databases and a Message Queue (Apache Artemis) and we are doing XA transaction between them. To implement JTA transactions in Java we use Atomikos.

      When using the MariaDB Connector/J in the version provided by Spring Boot 3.x (v 3.3.3) or higher (v 3.4.0) we get the same errors as stated in a former bug ticket https://jira.mariadb.org/browse/CONJ-122.

      The error message shows as follows:

      com.atomikos.datasource.ResourceException: XA resource 'xaDataSource': resume for XID 'XID: 3139322E3136382E3137382E3130302E746D313731393939353238343032333030303238:3139322E3136382E3137382E3130302E746D3237' raised -5: invalid arguments were given for the XA operation
      	at com.atomikos.datasource.xa.XAResourceTransaction.resume(XAResourceTransaction.java:223) ~[transactions-jta-6.0.0-jakarta.jar:na]
      	at com.atomikos.datasource.xa.session.BranchEnlistedStateHandler.<init>(BranchEnlistedStateHandler.java:40) ~[transactions-jta-6.0.0-jakarta.jar:na]
      	at com.atomikos.datasource.xa.session.NotInBranchStateHandler.checkEnlistBeforeUse(NotInBranchStateHandler.java:46) ~[transactions-jta-6.0.0-jakarta.jar:na]
      	at com.atomikos.datasource.xa.session.TransactionContext.checkEnlistBeforeUse(TransactionContext.java:58) ~[transactions-jta-6.0.0-jakarta.jar:na]
      	at com.atomikos.datasource.xa.session.SessionHandleState.notifyBeforeUse(SessionHandleState.java:165) ~[transactions-jta-6.0.0-jakarta.jar:na]
      	at com.atomikos.jdbc.internal.AtomikosJdbcConnectionProxy.enlist(AtomikosJdbcConnectionProxy.java:88) ~[transactions-jdbc-6.0.0-jakarta.jar:na]
      	at com.atomikos.jdbc.internal.AtomikosJdbcConnectionProxy.updateTransactionContext(AtomikosJdbcConnectionProxy.java:61) ~[transactions-jdbc-6.0.0-jakarta.jar:na]
      	at com.atomikos.jdbc.internal.AbstractJdbcConnectionProxy.prepareStatement(AbstractJdbcConnectionProxy.java:64) ~[transactions-jdbc-6.0.0-jakarta.jar:na]
      	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:na]
      	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[na:na]
      	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:na]
      	at java.base/java.lang.reflect.Method.invoke(Method.java:568) ~[na:na]
      	at com.atomikos.util.DynamicProxySupport.callProxiedMethod(DynamicProxySupport.java:164) ~[atomikos-util-6.0.0.jar:na]
      	at com.atomikos.util.DynamicProxySupport.invoke(DynamicProxySupport.java:121) ~[atomikos-util-6.0.0.jar:na]
      ...
      ...
      ...
      

      This behavior is also stated by Atomikos here: http://www.atomikos.com/Documentation/KnownProblems#MySQL_does_not_support_TMJOIN

      The method to fix this was setting a connection string parameter:

      pinGlobalTxToPhysicalConnection="true"
      

      This parameter was removed in the newer MariaDB Connector/J versions as stated here: MariaDB Connector/J 2.7 -> 3.4 Upgrade

      Using the Mysql Connector/J driver with MariaDB and the mentioned parameter works as intended but introduces other problems (e.g. Hibernate not recognizing the right dialect and giving warnings due to not resolve the right DB version etc.)

      Please reintroduce the parameter

      pinGlobalTxToPhysicalConnection
      

      or give us another posibility to get along with this issue.

      Attachments

        Issue Links

          Activity

            gbalthasar Gregor Balthasar created issue -
            gbalthasar Gregor Balthasar made changes -
            Field Original Value New Value
            diego dupin Diego Dupin added a comment -

            to be honest, this has not been done, because there were no explaination about this option and very few documentation. It will be done in 3.x branch now, and with proper documentation.

            diego dupin Diego Dupin added a comment - to be honest, this has not been done, because there were no explaination about this option and very few documentation. It will be done in 3.x branch now, and with proper documentation.
            diego dupin Diego Dupin made changes -
            Fix Version/s 3.4.1 [ 29841 ]
            diego dupin Diego Dupin added a comment -

            Just curious, but didn't you have issue with 2.x implementation as well ? It seems to me that CONJ-122 was doing only half the job.

            diego dupin Diego Dupin added a comment - Just curious, but didn't you have issue with 2.x implementation as well ? It seems to me that CONJ-122 was doing only half the job.

            This is great news, we are looking forward to it!

            Probably you are right, we tried so much lately that I got a little bit confused. We never used the 2.x implementation but started with 3.1.4 as it was part of Spring Boot 2.x and 3.1.4 did not work either. Then I wondered if the parameter did do nothing and found the upgrade document which stated it to be gone. In the meantime we upgraded to Spring Boot 3.x which brings 3.3.3 so i based this ticket on it.

            gbalthasar Gregor Balthasar added a comment - This is great news, we are looking forward to it! Probably you are right, we tried so much lately that I got a little bit confused. We never used the 2.x implementation but started with 3.1.4 as it was part of Spring Boot 2.x and 3.1.4 did not work either. Then I wondered if the parameter did do nothing and found the upgrade document which stated it to be gone. In the meantime we upgraded to Spring Boot 3.x which brings 3.3.3 so i based this ticket on it.
            diego dupin Diego Dupin made changes -
            Resolution Fixed [ 1 ]
            Status Open [ 1 ] Closed [ 6 ]

            Hi,

            thanks for the quick resolving of this issue! Any chance for getting a nightly build via sonatype anytime soon so we could test this in our environment?

            Many thanks,
            Gregor

            gbalthasar Gregor Balthasar added a comment - Hi, thanks for the quick resolving of this issue! Any chance for getting a nightly build via sonatype anytime soon so we could test this in our environment? Many thanks, Gregor
            diego dupin Diego Dupin added a comment -

            this is available throught snapshot using :

            <repositories>
            	<repository>
            		<id>sonatype-nexus-snapshots</id>
            		<name>Sonatype Nexus Snapshots</name>
            		<url>https://oss.sonatype.org/content/repositories/snapshots</url>
            	</repository>
            </repositories>
             
            <dependencies>
            	<dependency>
            		<groupId>org.mariadb.jdbc</groupId>
            		<artifactId>mariadb-java-client</artifactId>
            		<version>3.4.1-SNAPSHOT</version>
            	</dependency>
            </dependencies>
            

            diego dupin Diego Dupin added a comment - this is available throught snapshot using : <repositories> <repository> <id>sonatype-nexus-snapshots</id> <name>Sonatype Nexus Snapshots</name> <url>https: //oss.sonatype.org/content/repositories/snapshots</url> </repository> </repositories>   <dependencies> <dependency> <groupId>org.mariadb.jdbc</groupId> <artifactId>mariadb-java-client</artifactId> <version> 3.4 . 1 -SNAPSHOT</version> </dependency> </dependencies>
            gbalthasar Gregor Balthasar added a comment - - edited

            Unfortunately, this is not solving our problem yet. Now we get the same error from the newly introduced 'MariaDbPoolPinnedConnection':

            2024-07-08T16:10:56.330+02:00  WARN 14647 --- [           main] c.a.datasource.xa.XAResourceTransaction  : XA resource 'xaDataSource': resume for XID 'XID: 3139322E3136382E3137382E3130302E746D313732303434373633313234303030303032:3139322E3136382E3137382E3130302E746D31' raised -5: invalid arguments were given for the XA operation
             
            javax.transaction.xa.XAException: null
            	at org.mariadb.jdbc.MariaDbPoolConnection.mapXaException(MariaDbPoolConnection.java:180) ~[mariadb-java-client-3.4.1-20240708.122651-3.jar:na]
            	at org.mariadb.jdbc.MariaDbPoolPinnedConnection$MariaDbXAPinnedResource.execute(MariaDbPoolPinnedConnection.java:69) ~[mariadb-java-client-3.4.1-20240708.122651-3.jar:na]
            	at org.mariadb.jdbc.MariaDbPoolPinnedConnection$MariaDbXAPinnedResource.start(MariaDbPoolPinnedConnection.java:166) ~[mariadb-java-client-3.4.1-20240708.122651-3.jar:na]
            	at com.atomikos.datasource.xa.XAResourceTransaction.resume(XAResourceTransaction.java:217) ~[transactions-jta-6.0.0-jakarta.jar:na]
            	at com.atomikos.datasource.xa.session.BranchEnlistedStateHandler.<init>(BranchEnlistedStateHandler.java:40) ~[transactions-jta-6.0.0-jakarta.jar:na]
            	at com.atomikos.datasource.xa.session.NotInBranchStateHandler.checkEnlistBeforeUse(NotInBranchStateHandler.java:46) ~[transactions-jta-6.0.0-jakarta.jar:na]
            	at com.atomikos.datasource.xa.session.TransactionContext.checkEnlistBeforeUse(TransactionContext.java:58) ~[transactions-jta-6.0.0-jakarta.jar:na]
            	at com.atomikos.datasource.xa.session.SessionHandleState.notifyBeforeUse(SessionHandleState.java:165) ~[transactions-jta-6.0.0-jakarta.jar:na]
            	at com.atomikos.jdbc.internal.AtomikosJdbcConnectionProxy.enlist(AtomikosJdbcConnectionProxy.java:88) ~[transactions-jdbc-6.0.0-jakarta.jar:na]
            	at com.atomikos.jdbc.internal.AtomikosJdbcConnectionProxy.updateTransactionContext(AtomikosJdbcConnectionProxy.java:61) ~[transactions-jdbc-6.0.0-jakarta.jar:na]
            	at com.atomikos.jdbc.internal.AbstractJdbcConnectionProxy.prepareStatement(AbstractJdbcConnectionProxy.java:64) ~[transactions-jdbc-6.0.0-jakarta.jar:na]
            

            I did some digging and debugging and the chain of executes is like: START <ID>, END <ID>, START<ID> -> Exception -> Rollback. I am not sure why END is called while just staying in the same transaction and performing multiple readonly DB selects via Hibernate while in Atomikos XA transaction environment. As stated before, the same code using the mysql-connector-j driver addressing the same MariaDB database is working just fine.

            Best regards,
            Gregor

            PS: I just debugged the mysql-connector-j 'SuspendableXAConnection' and found that it changes the 'TMJOIN' flag at the START command to a 'TMRESUME' flag. Maybe this is what is causing the error we are getting now since afaik neither Mysql nor MariaDB support the JOIN command.

            gbalthasar Gregor Balthasar added a comment - - edited Unfortunately, this is not solving our problem yet. Now we get the same error from the newly introduced 'MariaDbPoolPinnedConnection': 2024 - 07 -08T16: 10 : 56.330 + 02 : 00 WARN 14647 --- [ main] c.a.datasource.xa.XAResourceTransaction : XA resource 'xaDataSource' : resume for XID 'XID: 3139322E3136382E3137382E3130302E746D313732303434373633313234303030303032:3139322E3136382E3137382E3130302E746D31' raised - 5 : invalid arguments were given for the XA operation   javax.transaction.xa.XAException: null at org.mariadb.jdbc.MariaDbPoolConnection.mapXaException(MariaDbPoolConnection.java: 180 ) ~[mariadb-java-client- 3.4 . 1 - 20240708.122651 - 3 .jar:na] at org.mariadb.jdbc.MariaDbPoolPinnedConnection$MariaDbXAPinnedResource.execute(MariaDbPoolPinnedConnection.java: 69 ) ~[mariadb-java-client- 3.4 . 1 - 20240708.122651 - 3 .jar:na] at org.mariadb.jdbc.MariaDbPoolPinnedConnection$MariaDbXAPinnedResource.start(MariaDbPoolPinnedConnection.java: 166 ) ~[mariadb-java-client- 3.4 . 1 - 20240708.122651 - 3 .jar:na] at com.atomikos.datasource.xa.XAResourceTransaction.resume(XAResourceTransaction.java: 217 ) ~[transactions-jta- 6.0 . 0 -jakarta.jar:na] at com.atomikos.datasource.xa.session.BranchEnlistedStateHandler.<init>(BranchEnlistedStateHandler.java: 40 ) ~[transactions-jta- 6.0 . 0 -jakarta.jar:na] at com.atomikos.datasource.xa.session.NotInBranchStateHandler.checkEnlistBeforeUse(NotInBranchStateHandler.java: 46 ) ~[transactions-jta- 6.0 . 0 -jakarta.jar:na] at com.atomikos.datasource.xa.session.TransactionContext.checkEnlistBeforeUse(TransactionContext.java: 58 ) ~[transactions-jta- 6.0 . 0 -jakarta.jar:na] at com.atomikos.datasource.xa.session.SessionHandleState.notifyBeforeUse(SessionHandleState.java: 165 ) ~[transactions-jta- 6.0 . 0 -jakarta.jar:na] at com.atomikos.jdbc.internal.AtomikosJdbcConnectionProxy.enlist(AtomikosJdbcConnectionProxy.java: 88 ) ~[transactions-jdbc- 6.0 . 0 -jakarta.jar:na] at com.atomikos.jdbc.internal.AtomikosJdbcConnectionProxy.updateTransactionContext(AtomikosJdbcConnectionProxy.java: 61 ) ~[transactions-jdbc- 6.0 . 0 -jakarta.jar:na] at com.atomikos.jdbc.internal.AbstractJdbcConnectionProxy.prepareStatement(AbstractJdbcConnectionProxy.java: 64 ) ~[transactions-jdbc- 6.0 . 0 -jakarta.jar:na] I did some digging and debugging and the chain of executes is like: START <ID>, END <ID>, START<ID> -> Exception -> Rollback. I am not sure why END is called while just staying in the same transaction and performing multiple readonly DB selects via Hibernate while in Atomikos XA transaction environment. As stated before, the same code using the mysql-connector-j driver addressing the same MariaDB database is working just fine. Best regards, Gregor PS: I just debugged the mysql-connector-j 'SuspendableXAConnection' and found that it changes the 'TMJOIN' flag at the START command to a 'TMRESUME' flag. Maybe this is what is causing the error we are getting now since afaik neither Mysql nor MariaDB support the JOIN command.
            diego dupin Diego Dupin added a comment -

            ah, yes this is missing.
            https://github.com/mariadb-corporation/mariadb-connector-j/commit/f68447f17a14461642415167d93f21cfc6ebaed4 added.

            3.4.1-SNAPSHOT version updated. Could you confirm the correction ?

            diego dupin Diego Dupin added a comment - ah, yes this is missing. https://github.com/mariadb-corporation/mariadb-connector-j/commit/f68447f17a14461642415167d93f21cfc6ebaed4 added. 3.4.1-SNAPSHOT version updated. Could you confirm the correction ?
            diego dupin Diego Dupin made changes -
            Resolution Fixed [ 1 ]
            Status Closed [ 6 ] Stalled [ 10000 ]

            This is doing the trick!

            Our whole test suite now runs without errors now with 3.4.1-snapshot. We really appreciate your work, with 3.4.1 we can then switch back to mariadb-connector-j which is great news for us.

            Many thanks again and hopefully 3.4.1 is released soon

            Best regards,
            Gregor

            gbalthasar Gregor Balthasar added a comment - This is doing the trick! Our whole test suite now runs without errors now with 3.4.1-snapshot. We really appreciate your work, with 3.4.1 we can then switch back to mariadb-connector-j which is great news for us. Many thanks again and hopefully 3.4.1 is released soon Best regards, Gregor
            diego dupin Diego Dupin made changes -
            Resolution Fixed [ 1 ]
            Status Stalled [ 10000 ] Closed [ 6 ]

            People

              diego dupin Diego Dupin
              gbalthasar Gregor Balthasar
              Votes:
              0 Vote for this issue
              Watchers:
              2 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved:

                Git Integration

                  Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.