簡體   English   中英

添加新的Datasource(mysql)wildfly

[英]Add new Datasource (mysql) wildfly

我正在嘗試將新的數據源mysql jdbc驅動程序添加到我的wildfly服務器

我創建了文件夾wildfly.xxx/modules/system/layers/base/com/mysql/main我這里有jdbc jar文件和module.xml

<module xmlns="urn:jboss:module:1.3" name="com.mysql">
        <resources>
         <resource-root path="mysql-connector-java-5.1.34-bin.jar"/>
     </resources>
     <dependencies>
      <module name="javax.api"/>
     </dependencies>
    </module>

然后將dataresource代碼添加到standalone-full.xml(在datareources標記下)

 <datasource jndi-name="java:jboss/datasources/MySQLDS" pool-name="MySQLDS"     enabled="true" use-java-context="true">
 <connection-url>jdbc:mysql://localhost:3306/test</connection-url>
 <driver>MySQLDriver</driver>
<security>
 <user-name>root</user-name>
 <password></password>
</security>
</datasource>

但當我去wildfly控制面板http://localhost:9990/console/ dataresource沒出現時,我錯過了什么?

我也試圖從界面手動添加它我得到了這個錯誤

Unexpected HTTP response: 500

Request
{
    "address" => [
        ("subsystem" => "datasources"),
        ("data-source" => "mysql")
    ],
    "operation" => "test-connection-in-pool"
}

Response

Internal Server Error
{
    "outcome" => "failed",
    "failure-description" => "JBAS010440: failed to invoke operation: JBAS010447: Connection is not valid",
    "rolled-back" => true
} 

您是否添加了驅動程序定義? 您的datasources子系統應如下所示:

    <subsystem xmlns="urn:jboss:domain:datasources:2.0">
        <datasources>
            <datasource jndi-name="java:/jdbc/myds" pool-name="myds" enabled="true" use-java-context="true">
                <connection-url>jdbc:mysql://localhost/mydb</connection-url>
                <driver>mysql</driver>
                <security>
                    <user-name>foo</user-name>
                    <password>bar</password>
                </security>
            </datasource>
            <drivers>
                <driver name="h2" module="com.h2database.h2">
                    <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
                </driver>
                <driver name="mysql" module="com.mysql">
                    <xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</xa-datasource-class>
                </driver>
            </drivers>
        </datasources>
    </subsystem>

driver在數據源定義元件必須引用driver通過name元素。 module屬性必須與MySQL驅動程序模塊的名稱匹配。

實際上我遇到了同樣的問題(我之前可以成功添加數據源和測試連接)所以我只是困惑,我發現一種適合我的方式:)

看到我的服務,我發現它已停止,然后我開始嘗試再次嘗試,它再次運行良好! 即使您的服務沒有停止,也許只是重新啟動它。 我不得不說如果你之前沒有成功連接它可能不適合你,祝你好運〜

在此輸入圖像描述

在此輸入圖像描述

三種方法可以簡單地將數據源創建為wildfly

  1. 使用管理控制台
  2. 手動添加到standalone.xml
  3. 創建xml文件的數據源文件。

轉到WildFly目錄/ standalone / deployments使用以下內容創建數據源xml的最簡單方法

<datasources xmlns="http://www.jboss.org/ironjacamar/schema">
      <datasource jndi-name="APP_DS" pool-name="APP_DS" enabled="true" use-ccm="false">
        <connection-url>jdbc:mysql://localhost:3306/DB_NAME</connection-url>
        <driver-class>com.mysql.jdbc.Driver</driver-class>
        <driver>mysql</driver>

        <!-- sql to call when connection is created -->
        <new-connection-sql>SELECT 1</new-connection-sql>

        <pool>
            <min-pool-size>5</min-pool-size>
            <max-pool-size>50</max-pool-size>
        </pool>

        <security>
          <user-name>username</user-name>
          <password>password</password>
        </security>

        <!-- sql to call on an existing pooled connection when it is obtained from pool -->
        <validation>
        <check-valid-connection-sql>SELECT 1</check-valid-connection-sql>
        </validation>

        <timeout>
        <blocking-timeout-millis>300000</blocking-timeout-millis>
        <idle-timeout-minutes>5</idle-timeout-minutes>
        </timeout>
        <statement>
        <track-statements>true</track-statements>
        </statement>      
      </datasource>
    </datasources>

還要創建要使用的數據庫。 有時,此錯誤的原因是數據庫丟失。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM