尝试查找context.xml

时间:2016-12-27 16:29:44

标签: java tomcat jboss

我正在向JBoss EAP 7部署WAR。在我的WAR META-INF/context.xml文件中,我有以下内容:

<Context unloadDelay="500000">
    <Resource name="jdbc/sybase/somedb"
          auth="Container"
          type="javax.sql.DataSource"
          driverClassName="net.sourceforge.jtds.jdbc.Driver"
          url="jdbc:jtds:sybase://localhost:12501/somedb"
          username="username" password="secret"
          validationQuery="select 1"              
          maxActive="2" maxIdle="0" maxWait="-1"/>          
...

从我的Java代码中,我尝试获取DataSource:

InitialContext cxt = new InitialContext(); 
DataSource ds = (DataSource) cxt.lookup( "java:/comp/env/jdbc/sybase/somedb" );

上面的代码工作,在我部署到Tomcat 8时,上下文中的名称是找到,但在部署到JBoss EAP 7时却没有。在后一种情况下我明白了:

Caused by: javax.naming.NameNotFoundException: comp/env/jdbc/sybase/somedb -- service jboss.naming.context.java.comp.env.jdbc.sybase.somedb
at org.jboss.as.naming.ServiceBasedNamingStore.lookup(ServiceBasedNamingStore.java:106)
at org.jboss.as.naming.NamingContext.lookup(NamingContext.java:207)
at org.jboss.as.naming.InitialContext$DefaultInitialContext.lookup(InitialContext.java:235)
at org.jboss.as.naming.NamingContext.lookup(NamingContext.java:193)
at org.jboss.as.naming.NamingContext.lookup(NamingContext.java:189)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at javax.naming.InitialContext.lookup(InitialContext.java:417)

我做错了什么,如何解决上述问题?

1 个答案:

答案 0 :(得分:2)

您的META-INF/context.xml文件是Tomcat部署描述符(未由Java EE规范定义),因此JBoss EAP 7无法查看或解析它。

有很多替代方案,包括is there a standard way to define a JDBC Datasource for Java EE containers的解决方案。

如果您要求RedHat支持,他们可能会建议您使用服务器管理工​​具(例如管理控制台或jboss-cli.sh)创建数据源。这会将您的应用程序与数据源定义分离,以便您可以指定特定于环境的设置(例如池大小和主机名),而无需重新打包WAR.file。此方法还要求您与应用程序分开部署JDBC驱动程序jar。