如何在 Wildfly 10 上设置 MariaDB JNDI?

How to setup MariaDB JNDI on Wildfly 10?

我正在尝试将我的 Tomcat 网络服务移动到 Wildfly 10。我认为它应该被拖放到 Wildfly 的部署文件夹中,一切都应该没问题,但似乎不是那样。

这是我在 standalone.xml:

中的 MariaDB 数据源定义
<datasource jndi-name="java:jboss/MariaDBDS" pool-name="MariaDBDS">
    <connection-url>jdbc:mariadb://db_ip/db_name</connection-url>
    <driver>mariadb</driver>
    <security>
        <user-name>dbAcc</user-name>
        <password>dbPassword</password>
    </security>
    <validation>
        <valid-connection-checker class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLValidConnectionChecker"/>
        <validate-on-match>true</validate-on-match>
        <background-validation>false</background-validation>
        <exception-sorter class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLExceptionSorter"/>
    </validation>
    </datasource>
    <drivers>
        <driver name="mariadb" module="org.mariadb">
            <driver-class>org.mariadb.jdbc.Driver</driver-class>
            <xa-datasource-class>org.mariadb.jdbc.MariaDbDataSource</xa-datasource-class>
        </driver>
    </drivers>

然后我将 mariadb-java-client-1.4.6.jar 和我的 WAR 文件放入 wildfly/standalone/deployments,启动 Wildfly,然后出现错误消息:

07:05:21,137 INFO  [org.wildfly.extension.undertow] (ServerService Thread Pool -- 60) WFLYUT0021: Registered web context: /MySV
07:05:21,143 ERROR [org.jboss.as.controller.management-operation] (Controller Boot Thread) WFLYCTL0013: Operation ("add") failed - address: ([
("subsystem" => "datasources"),
("data-source" => "MariaDBDS")
]) - failure description: {
"WFLYCTL0412: Required services that are not installed:" => ["jboss.jdbc-driver.mariadb"],
"WFLYCTL0180: Services with missing/unavailable dependencies" => [
    "jboss.driver-demander.java:jboss/MariaDBDS is missing [jboss.jdbc-driver.mariadb]",
    "org.wildfly.data-source.MariaDBDS is missing [jboss.jdbc-driver.mariadb]"
]
}
07:05:21,148 ERROR [org.jboss.as.controller.management-operation] (Controller Boot Thread) WFLYCTL0013: Operation ("add") failed - address: ([
("subsystem" => "datasources"),
("data-source" => "MariaDBDS")
]) - failure description: {
"WFLYCTL0412: Required services that are not installed:" => [
    "jboss.jdbc-driver.mariadb",
    "jboss.jdbc-driver.mariadb"
],
"WFLYCTL0180: Services with missing/unavailable dependencies" => [
    "jboss.driver-demander.java:jboss/MariaDBDS is missing [jboss.jdbc-driver.mariadb]",
    "org.wildfly.data-source.MariaDBDS is missing [jboss.jdbc-driver.mariadb]",
    "org.wildfly.data-source.MariaDBDS is missing [jboss.jdbc-driver.mariadb]"
]
}

我无法让我的服务连接到数据库,我是否错过了任何步骤?

如果我查看您的配置,您将驱动程序设置为一个模块。因此,您将其创建为服务器中的一个模块,而不是将其作为单独的 jar 部署在部署文件夹中。

如果你想在部署文件夹中的驱动程序中设置数据源,你可以这样做:

<datasource jndi-name="java:jboss/MariaDBDS" pool-name="MariaDBDS">
    <connection-url>jdbc:mariadb://db_ip/db_name</connection-url>
    <driver>mariadb-java-client-1.4.6.jar</driver>
    <driver-class>org.mariadb.jdbc.Driver</driver-class>
    <security>
        <user-name>dbAcc</user-name>
        <password>dbPassword</password>
    </security>
    <validation>
        <valid-connection-checker class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLValidConnectionChecker"/>
        <validate-on-match>true</validate-on-match>
        <background-validation>false</background-validation>
        <exception-sorter class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLExceptionSorter"/>
    </validation>
</datasource>

不需要单独的驱动程序声明,它都包含在数据源配置中。