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

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

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

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

      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      69 隨筆 :: 0 文章 :: 25 評(píng)論 :: 0 Trackbacks
    今天為了這個(gè)問(wèn)題了忙乎了一整天,特此記錄下,希望對(duì)有遇到同樣問(wèn)題的同學(xué)有幫助。事情的經(jīng)過(guò)是這樣的,原先使用atomikos一直把數(shù)據(jù)源用jndi配置到tomcat的context.xml下,一直這么用沒(méi)有出現(xiàn)問(wè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)上的,所以覺(jué)得沒(méi)有問(wèn)題,可是項(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èn)題,上網(wǎng)查資料,據(jù)說(shuō)是mysql xa bug,有興趣的可以看如下連接,最后配置如下:
           <property name="xaProperties">  
                
    <props>
                    
    <prop key="pinGlobalTxToPhysicalConnection">true</prop>  <!-- mysql必須配置此參數(shù),要不然無(wú)法提交事務(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 閱讀(2485) 評(píng)論(0)  編輯  收藏 所屬分類: java
    主站蜘蛛池模板: 苍井空亚洲精品AA片在线播放| 国产成人精品日本亚洲专| 又粗又长又爽又长黄免费视频 | 久久久久久精品免费免费自慰| 国产亚洲AV无码AV男人的天堂| 巨胸喷奶水视频www免费视频| 久久久久亚洲AV综合波多野结衣| 少妇亚洲免费精品| 国产亚洲一区二区三区在线不卡| 国产99久久久久久免费看| 国产日韩亚洲大尺度高清| 四虎影视成人永久免费观看视频| 亚洲老熟女@TubeumTV| 免费不卡视频一卡二卡| 亚洲精品美女久久7777777| 日韩午夜免费视频| 人体大胆做受免费视频| 亚洲AV无码专区国产乱码电影| 99视频精品全部免费观看| 麻豆狠色伊人亚洲综合网站| 国产精品色午夜免费视频| 一区二区在线免费视频| 亚洲动漫精品无码av天堂| 国产麻豆视频免费观看| 偷自拍亚洲视频在线观看| 亚洲情XO亚洲色XO无码| 每天更新的免费av片在线观看| 亚洲中文字幕久久久一区| 亚洲精品综合久久| 人妻无码一区二区三区免费 | 好爽…又高潮了毛片免费看 | 亚洲视频在线观看网站| 免费看少妇作爱视频| 中文字幕版免费电影网站| 亚洲日本乱码一区二区在线二产线 | 青青草97国产精品免费观看| 亚洲AV无码国产精品色午友在线| 成视频年人黄网站免费视频| 9i9精品国产免费久久| 亚洲乱码日产精品BD在线观看| 亚洲国产精品不卡毛片a在线|