问题描述
我正在开发Java Web应用程序,并且正在Websphere Application Server中进行部署,
我有一个类Database.java,它将返回与DB2数据库的JDBC连接,
jndiName = "jdbc/TestDataSource";
Context ctx = new InitialContext();
envContext = (Context) ctx.lookup("java:comp/env");
javax.sql.DataSource ds = (javax.sql.DataSource) envContext.lookup(jndiName);
conn = ds.getConnection();
以及在其他正在执行操作的类中,创建Database.java类的对象并获取连接并执行了jdbc操作,到目前为止,它仍然可以正常工作,但是在最新开发中,我必须在servlet类中引入一个线程,因此正在执行操作的其他类在后台在线程中运行,并将控件立即返回给servlet。但是,在实现该应用程序后,它在Websphere Application Server中崩溃并出现以下错误,但令人惊讶的是它的运行状况非常好。
PFB Web.xml
<resource-ref>
<description>Connection-ConnectionPool</description>
<res-ref-name>jdbc/TestDataSource</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
<res-sharing-scope>Shareable</res-sharing-scope>
<mapped-name>jdbc/TestDataSource</mapped-name>
</resource-ref>
错误: 000000e9 SystemOut O NamingException中的错误-Database.getConnection(datasource):-javax.naming.ConfigurationException:无法完成对“ java:”名称的JNDI操作,因为服务器运行时无法将操作线程与任何J2EE应用程序相关联零件。当未在服务器应用程序请求的线程上执行使用“ java:”名称的JNDI客户端时,会发生这种情况。确保J2EE应用程序不在静态代码块或该J2EE应用程序创建的线程中的“ java:”名称上执行JNDI操作。这样的代码不一定在服务器应用程序请求的线程上运行,因此JNDI操作不支持“ java:”名称。 [根异常是javax.naming.NameNotFoundException:在上下文“ java:comp / env”中找不到名称jdbc。]
解决方法
该异常意味着您创建的线程没有Java EE应用程序的上下文,因此它不知道从哪个Java EE组件名称空间获取java:comp/env/jdbc/TestDataSource
。请注意,您可以定义相同的名称,以表示不同的Java EE应用程序/组件的不同含义。有一个简单的方法可以遵循Java EE规范标准。与其创建自己的线程,不如使用ManagedExecutorService(也是Java EE的一部分),该服务将应用程序的上下文自动传播到托管线程,在这种情况下,应用服务器将能够正确解析查找。
这里是一个例子:
ExecutorService executor = InitialContext.doLookup("java:comp/DefaultManagedExecutorService");
executor.submit(new Callable<Object>() {
public Object call() throws Exception {
DataSource ds = InitialContext.doLookup("java:comp/env/jdbc/TestDataSource");
Connection conn = ds.getConnection();
try {
// ... do useful stuff with connection
} finally {
conn.close();
}
return result;
}
});