我正在尝试在 Mule Studio 中使用 Oracle 数据库连接器实现 XA 事务。当我尝试在 MuleStudio 服务器上部署这个 mule 应用程序时,我遇到了异常。
例外:
“引起:org.springframework.beans.NotWritablePropertyException:bean类[oracle.jdbc.xa.client.OracleXADataSource]的无效属性'url':bean属性'url'不可写或具有无效的setter方法。是否参数setter 的类型是否与 getter 的返回类型匹配?”
骡配置xml文件:
<jdbc-ee:oracle-data-source name="Oracle_Data_Source" user="system" password="manager" url="jdbc:oracle:thin:@//localhost:1521/xe" transactionIsolation="UNSPECIFIED" doc:name="Oracle Data Source"/>
<jdbc-ee:connector name="Database" dataSource-ref="oracleJdbcBean" validateConnections="true" queryTimeout="-1" pollingFrequency="0" doc:name="Database"/>
<jbossts:transaction-manager doc:name="Transaction Manager"/>
<spring:beans>
<spring:bean id="oracleJdbcBean" name="oracleJdbcBean" class="oracle.jdbc.xa.client.OracleXADataSource">
<spring:property name="user" value="system"/>
<spring:property name="password" value="manager"/>
<spring:property name="url" value="jdbc:oracle:thin:@localhost:1521:xe"/>
</spring:bean>
</spring:beans>
<flow name="oraclexatransactionFlow1" doc:name="oraclexatransactionFlow1">
<http:inbound-endpoint exchange-pattern="request-response" host="localhost" port="8082" path="testTable" doc:name="HTTP"/>
<ee:xa-transactional action="ALWAYS_BEGIN" doc:name="Transactional">
<jdbc-ee:outbound-endpoint exchange-pattern="request-response" queryKey="testQuery" queryTimeout="-1" connector-ref="Database" doc:name="Database">
<xa-transaction action="ALWAYS_JOIN"/>
<jdbc-ee:query key="testQuery" value="select * from test"/>
</jdbc-ee:outbound-endpoint>
</ee:xa-transactional>
</flow>
我已按照其他应用程序的上述配置使 xa 事务与 oracle 数据库一起使用,但我得到了不同的异常,如下所示:
引起:org.xml.sax.SAXParseException;行号:195;列号:55;cvc-complex-type.2.4.a:发现以元素“xa-transaction”开头的无效内容。'{" http://www.mulesoft.org/schema/mule/jdbc ":abstract-query}' 之一是预期的。
如果我配置有任何错误,请纠正我。