[英]JMS Connection problems in Tomcat
我正在尝试将一个旧的、大型的、基于 Weblogic 的应用程序移植到 Tomcat。 该应用程序使用 Spring、EclipseLink 和 Oracle 数据库。
有两个不同的数据库连接,两者几乎相同。 与 JSF 页面的连接工作正常。 不幸的是,JMS (Oracle AQ) 没有。 这是我得到的错误:
我的应用程序 | 17:17:34,177 错误 XmlMessageListenerContainer.refreshConnectionUntilSuccessful 无法刷新目标“SPFR_EVENT_Q”的 JMS 连接 - 使用 FixedBackOff{interval=5000,currentAttempts=4,maxAttempts=unlimited} 重试。 原因:创建 db_connection 时出错; nested exception is java.lang.ClassCastException: com.sun.proxy.$Proxy51 cannot be cast to oracle.jdbc.internal.OracleConnection
这是相关的连接:
<Resource
name="jdbc/myAQDS"
auth="Container"
type="javax.sql.DataSource"
factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
driverClassName="oracle.jdbc.OracleDriver"
url="jdbc:oracle:thin:theurlhere"
username="theuser"
password="thepassword"
maxTotal="150"
maxIdle="10"
/>
任何想法是什么原因造成的? 我用谷歌搜索了具体的错误,结果完全空手而归。
Have a look at the Spring documentation here: https://docs.spring.io/spring-data/jdbc/old-docs/2.0.0.M1/reference/html/orcl.streamsaq.html Specifically the section about the NativeJdbcExtractor因为有一个 OracleJdbc4NativeJdbcExtractor 可用。
具体来说,请记住 Oracle AQ 连接工厂需要原生 Oracle 连接 object。 但是,应用服务器很可能包装了数据源连接 object。 因此,请尝试使用 OracleJdbc4NativeJdbcExtractor 作为 JMS 连接工厂的 nativeJdbcExtractor,它将用于解包连接并保持 Oracle 库满意。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.