如何解决为什么在使用SQL Anywhere sajdbc4驱动程序的Wildfly 20中测试连接失败?
我以前运行过Wildfly 10,并且刚刚升级到Wildfly 20(在Ubuntu 20下)。要使Sybase SQL Anywhere 17 sajdbc4驱动程序正常工作,我在Wildfly 10中的配置将不再起作用。当我“测试连接”失败时。我正在使用相同的配置,并针对完全相同的(SQL Anywhere高可用性)数据库服务器进行测试。
以下数据源上的“测试连接”触发“无效的ODBC句柄”错误:
<datasource jndi-name="java:jboss/datasources/TestDB" pool-name="TestDB" spy="true" tracking="true" enlistment-trace="true">
<connection-url>jdbc:sqlanywhere:Host=192.168.1.45:19000,192.168.1.45:19001;ServerName=TestDB</connection-url>
<driver>sajdbc4.jar</driver>
<security>
<user-name>...</user-name>
<password>...</password>
</security>
</datasource>
连接无效
原因:java.sql.SQLException:无效的ODBC句柄
at deployment.sajdbc4.jar//sap.jdbc4.sqlanywhere.IDriver.makeODBCConnection(Native Method)
at deployment.sajdbc4.jar//sap.jdbc4.sqlanywhere.IDriver.connect(IDriver.java:809)
at org.jboss.ironjacamar.jdbcadapters@1.4.22.Final//org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.createLocalManagedConnection(LocalManagedConnectionFactory.java:321)
... 35 more
我如何设置:
-
我使用控制台部署了sajdbc4.jar,看来工作正常。我没有看到任何错误,并且sajdbc4在控制台中显示为“已部署”,并且在子系统中也显示为JDBC驱动程序。这是使用控制台后在standalone.xml中创建的内容:
部署名称=“ sajdbc4.jar”运行时名称=“ sajdbc4.jar”> 内容sha1 =“ b690ff7a8ba1a3c2e8dd5079138b7970d969c2b9” /> / deployment>
(我必须放下前角括号才能显示前几行-即使标记为Code!) 接下来,我必须确保java.library.path和classpath包含sajdbc4.jar及其支持文件的路径,以便Wildfly可以找到它们。为此,我在standalone.conf中将“ HACK”添加到以下内容:
if [ "x$JAVA_OPTS" = "x" ]; then
JAVA_OPTS="-Xms64m -Xmx512m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m -Djava.net.preferIPv4Stack=true"
JAVA_OPTS="$JAVA_OPTS -Djboss.modules.system.pkgs=$JBOSS_MODULES_SYSTEM_PKGS -Djava.awt.headless=true"
# ADDED FOLLOWING HACK
JAVA_OPTS="$JAVA_OPTS -Djava.library.path=/opt/wildfly-20.0.1.Final/modules/system/layers/base/com/sybase/main -cp .:/opt/wildfly-20.0.1.Final/modules/system/layers/base/com/sybase/main/sajdbc4.jar"
echo "Java Properties Next:"
java -XshowSettings:properties -version
else
echo "JAVA_OPTS already set in environment; overriding default settings with values: $JAVA_OPTS"
fi
最后,我添加了顶部所示的数据源块。启动Wildfly之后,TestDB在数据源子系统中显示为数据源,但是当我测试连接时,出现“无效的ODBC句柄”错误。
我有信心驱动程序及其所有支持文件都在“运行”中,因为我有一个非常简单的Java测试应用程序,它仅与TestDB建立连接,从表中获取并显示行。请注意,它使用与我在standalone.conf中设置的完全相同的java.library.path和classpath:
cd $HOME/Desktop
export LD_LIBRARY_PATH=/opt/wildfly-20.0.1.Final/modules/system/layers/base/com/sybase/main
export CLASSPATH=.:/opt/wildfly-20.0.1.Final/modules/system/layers/base/com/sybase/main/sajdbc4.jar
java sajdbc4DriverTest.java
请注意,server.log没有显示任何错误,实际上显示的是这样的行:
[org.jboss.as.server.deployment] (MSC service thread 1-3) WFLYSRV0027: Starting deployment of "sajdbc4.jar" (runtime-name: "sajdbc4.jar")
...
[org.jboss.as.connector.deployers.jdbc] (MSC service thread 1-4) WFLYJCA0005: Deploying non-JDBC-compliant driver class sap.jdbc4.sqlanywhere.IDriver (version 4.0)
[org.jboss.as.connector.deployers.jdbc] (MSC service thread 1-3) WFLYJCA0018: Started Driver service with driver-name = sajdbc4.jar
[org.jboss.as.connector.subsystems.datasources] (MSC service thread 1-3) WFLYJCA0001: Bound data source [java:jboss/datasources/TestDB]
...
[org.jboss.as.server] (Controller Boot Thread) WFLYSRV0010: Deployed "sajdbc4.jar" (runtime-name : "sajdbc4.jar")
请注意,我的连接字符串用于连接到SQL Anywhere High Availability系统(因此有两个URL)。在Wildfly 20中,我看到控制台的“数据源定义”页面中现在有了一个新的“ HA URL分隔符”字段。我尝试将其设置为逗号,然后将“测试连接”错误更改为“无法从URL创建连接”:
2020-08-25 11:45:08,378 WARN [org.jboss.jca.core.connectionmanager.pool.strategy.OnePool] (External Management Request Threads -- 1) IJ000604: Throwable while attempting to get a new connection: null: javax.resource.ResourceException: IJ031085: Unable to create connection from URL: jdbc:sqlanywhere:Host=192.168.1.45:19000,192.168.1.45:19001;ServerName=TestDB
at org.jboss.ironjacamar.jdbcadapters@1.4.22.Final//org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getHALocalManagedConnection(LocalManagedConnectionFactory.java:381)
如何使“测试连接”正常工作?
谢谢。
解决方法
事实证明,该问题与我将Wildfly作为服务运行,并且显然我在上述设置java.library.path的努力失败有关。我知道错误的原因,但是我不知道在作为服务运行时如何设置路径。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。