如何解决根异常是javax.naming.NameNotFoundException:在上下文“ java:comp / env”中找不到名称jdbc
我正在开发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;
}
});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。