为什么在使用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 [email protected]//org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.createLocalManagedConnection(LocalManagedConnectionFactory.java:321)
... 35 more

我如何设置:

  1. 我使用控制台部署了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 [email protected]//org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getHALocalManagedConnection(LocalManagedConnectionFactory.java:381)

如何使“测试连接”正常工作?

谢谢。

解决方法

事实证明,该问题与我将Wildfly作为服务运行,并且显然我在上述设置java.library.path的努力失败有关。我知道错误的原因,但是我不知道在作为服务运行时如何设置路径。