我正在向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)
我做错了什么,如何解决上述问题?
答案 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。