一點(diǎn)一滴,編程人生

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            69 隨筆 :: 0 文章 :: 25 評(píng)論 :: 0 Trackbacks
          今天為了這個(gè)問題了忙乎了一整天,特此記錄下,希望對(duì)有遇到同樣問題的同學(xué)有幫助。事情的經(jīng)過是這樣的,原先使用atomikos一直把數(shù)據(jù)源用jndi配置到tomcat的context.xml下,一直這么用沒有出現(xiàn)問題,配置如下
              <Resource name="jdbc/cms" auth="Container"
                  type
          ="com.atomikos.jdbc.AtomikosDataSourceBean" factory="com.atomikos.tomcat.EnhancedTomcatAtomikosBeanFactory"
                  uniqueResourceName
          ="jdbc/cms" xaDataSourceClassName="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"
                  xaProperties.URL
          ="xxxx"
                  xaProperties.user
          ="xxxx" xaProperties.password="xxxx"
                  xaProperties.pinGlobalTxToPhysicalConnection
          ="true" maxLifetime="60" poolSize="4" />

          最近項(xiàng)目要遷移到maven下,所以把context.xml的數(shù)據(jù)源配置挪到了spring.xml下,配置如下
              <bean id="myDataSource" class="com.atomikos.jdbc.AtomikosDataSourceBean" init-method="init" destroy-method="close">
                 
          <property name="uniqueResourceName" value="masterDB" />
                 
          <property name="xaDataSourceClassName" value="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"/>  <!-- SQLErrorCodes loaded: [DB2, Derby, H2, HSQL, Informix, MS-SQL, MySQL, Oracle, PostgreSQL, Sybase, Hana]  -->  
                 
          <property name="poolSize" value="0" /> 
                 
          <property name="minPoolSize" value="0"/>    
                 
          <property name="maxPoolSize" value="9"/>    
                 
          <property name="borrowConnectionTimeout" value="60"/>    
                 
          <property name="reapTimeout" value="20"/>    
                 
          <property name="maxIdleTime" value="60"/>    
                 
          <property name="maintenanceInterval" value="60"/>    
                 
          <property name="loginTimeout" value="60"/>
                 
          <property name="xaProperties">  
                      
          <props>
                          
          <prop key="url">xxxx</prop>  
                          
          <prop key="user">xxxx</prop>
                          
          <prop key="password">xxxx</prop>
                      
          </props>
                  
          </property>  
              
          </bean>
          因?yàn)樯厦孢@個(gè)配置我是照搬網(wǎng)上的,所以覺得沒有問題,可是項(xiàng)目啟動(dòng)后,用此數(shù)據(jù)源提交事務(wù)時(shí)確報(bào)以下錯(cuò)誤:

          Raised -5: invalid arguments were given for the XA operation 或 XAER_INVAL: Invalid arguments (or unsupported command)

          一開始我以為maven配置的mysql-connector-java驅(qū)動(dòng)版本不對(duì),或是atomikos版本不對(duì),可是不管如何換版本都不行,就快要瘋了的時(shí)候,我看到了原先jndi方式中有這么一行代碼
          xaProperties.pinGlobalTxToPhysicalConnection="true"
          就因?yàn)槿鄙偕厦孢@句話導(dǎo)致了問題,上網(wǎng)查資料,據(jù)說是mysql xa bug,有興趣的可以看如下連接,最后配置如下:
                 <property name="xaProperties">  
                      
          <props>
                          
          <prop key="pinGlobalTxToPhysicalConnection">true</prop>  <!-- mysql必須配置此參數(shù),要不然無法提交事務(wù) -->
                          
          <prop key="url">xxxx</prop>  
                          
          <prop key="user">xxx</prop>
                          
          <prop key="password">xxxx</prop>
                      
          </props>
                  
          </property> 



          posted on 2017-06-28 19:32 writegull 閱讀(2506) 評(píng)論(0)  編輯  收藏 所屬分類: java
          主站蜘蛛池模板: 沈阳市| 佛学| 定日县| 东明县| 偏关县| 屏山县| 象山县| 重庆市| 上饶市| 彰化县| 江都市| 江达县| 蒲江县| 隆回县| 福泉市| 昌都县| 班戈县| 正阳县| 凤阳县| 军事| 建宁县| 柳河县| 体育| 始兴县| 宣武区| 贵阳市| 金门县| 邻水| 潞城市| 马关县| 兰西县| 兴宁市| 翼城县| 金寨县| 绥江县| 抚宁县| 社旗县| 龙川县| 河源市| 越西县| 景泰县|