<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    一點一滴,編程人生

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      69 隨筆 :: 0 文章 :: 25 評論 :: 0 Trackbacks

    2017年6月28日 #

    今天為了這個問題了忙乎了一整天,特此記錄下,希望對有遇到同樣問題的同學有幫助。事情的經(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" />

    最近項目要遷移到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>
    因為上面這個配置我是照搬網(wǎng)上的,所以覺得沒有問題,可是項目啟動后,用此數(shù)據(jù)源提交事務時確報以下錯誤:

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

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



    posted @ 2017-06-28 19:32 writegull 閱讀(2506) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 中文字幕免费视频| 久久精品私人影院免费看| 女人张开腿等男人桶免费视频| 国产A在亚洲线播放| 最近免费中文字幕MV在线视频3 | 久久性生大片免费观看性| 深夜国产福利99亚洲视频| 男男黄GAY片免费网站WWW| 又粗又硬又大又爽免费视频播放| 校园亚洲春色另类小说合集 | 亚洲精品无码久久久| 人妻18毛片a级毛片免费看| 不卡一卡二卡三亚洲| 毛片在线全部免费观看| 亚洲美女aⅴ久久久91| 欧美男同gv免费网站观看| 亚洲熟妇AV一区二区三区浪潮 | 国产精品69白浆在线观看免费 | 成人福利在线观看免费视频| 亚洲国产成人五月综合网| 9久热这里只有精品免费| 亚洲av日韩av激情亚洲| 国产99视频精品免费观看7| 亚洲aⅴ无码专区在线观看| 亚洲一级黄色视频| 91精品国产免费入口| 亚洲一级毛片在线播放| 国产一级淫片免费播放| a级在线免费观看| 亚洲jizzjizz在线播放久| 免费一级毛片女人图片| 永久免费A∨片在线观看| 亚洲中文字幕无码mv| 亚洲午夜精品一级在线播放放| 久久久99精品免费观看| 亚洲人成色777777老人头| 久久久久亚洲精品天堂久久久久久 | 亚洲AV综合永久无码精品天堂| 国产亚洲精aa成人网站| 97性无码区免费| 精品国产污污免费网站入口|