根异常是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操作,因为服务器运行时无法将操作线程与任何J2​​EE应用程序相关联零件。当未在服务器应用程序请求的线程上执行使用“ 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;
    }
});

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...