我正在使用JBoss7.1,并尝试通过ApplicationServer创建一个数据库连接池。我使用的是mysql数据库,但我也尝试了postgre数据库,错误是一样的。一切似乎都正常,但当我尝试访问应用程序时,控制台上出现了一个错误,提示我与数据库的连接失败。我的代码如下:
我的jboss standalone.xml。
<datasource jndi-name="java:jboss/jdbc/exampleDS" pool-name="jdbc/exampleDS" enabled="true" use-java-context="true" use-ccm="true">
<connection-url>jdbc:mysql://127.0.0.1:3306/example?useSSL=false</connection-url>
<driver>mysql-connector-java-5.1.43-bin.jar</driver>
<pool>
<min-pool-size>10</min-pool-size>
<max-pool-size>100</max-pool-size>
<prefill>true</prefill>
</pool>
<security>
<user-name>root</user-name>
<password>password</password>
</security>
<validation>
<valid-connection-checker class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLValidConnectionChecker"/>
<exception-sorter class-name="org.jboss.jca.adapters.jdbc.extensions.mysql.MySQLExceptionSorter"/>
</validation>
</datasource>
<driver name="mysql-connector-java-5.1.43-bin.jar" module="com.mysql">
<xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlDataSource</xa-datasource-class>
</driver>
我的web.xml
<resource-ref>
<description>example</description>
<res-ref-name>jdbc/exampleDS</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
我的Java代码
private ServiceLocator() {
try {
this.initCtx = new InitialContext();
this.envCtx = (Context) initCtx.lookup("java:comp/env");
DataSource ds = (DataSource)
envCtx.lookup("jdbc/exampleDS");
} catch (NamingException e) {
ApplicationException apRE = new ApplicationException(ErrorCode.E_JDNI001, e);
LogService.getLog().fatal(apRE.getMessage(), apRE);
throw apRE;
}
}
最后,当我启动jboss服务器时,没有出现错误,但是控制台说数据库的表不存在。
我感谢你的帮助
1条答案
按热度按时间ddarikpa1#
我已经纠正了这个错误。首先要做的是创建一个jboss-web.xml,其中web.xml,在我的例子中是webapp/web-inf
创建之后,我们必须在modules->com->mysql->main中创建module.xml,包含以下内容:
您还必须在主目录中插入您使用的.jar。关于Java代码,您需要更改initctx.lookup(“java:comp/env"); 为此:initctx.lookup(“java:”);
仅此而已:)