JDBC连接池设置无法在Glassfish5上运行

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JDBC连接池设置无法在Glassfish5上运行相关的知识,希望对你有一定的参考价值。

我目前是Glassfish应用服务器的新手,我一直在线使用管理界面在服务器上设置JDBC连接池。

我可以看到创建的连接池与服务器上默认创建的两个连接池一起列出,如下面的屏幕截图所示

enter image description here

我将此设置固定以确保一切正常,但是当我尝试从下面的代码清单中获取与数据库的连接时

public static Connection getDatabaseConnection()
{
    Connection con = null;
    try {
        Context initialContext = new InitialContext();

        if ( initialContext == null){
            System.out.println("JNDI problem. Cannot get InitialContext.");
        }
        DataSource datasource = (DataSource)initialContext.lookup("AppDb");
        if (datasource != null) {
            con = datasource.getConnection();
        }
        else {
            System.out.println("Failed to lookup datasource.");
        }

    }
    catch(Exception ex)
    {
        System.out.println("error looking up connection");
        ex.printStackTrace();
    }


    return con;
   }

但我在下面得到以下错误,说明找不到连接

javax.naming.NamingException: Lookup failed for 'AppDb' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: AppDb not found]
at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:491)
at com.sun.enterprise.naming.impl.SerialContext.lookup(SerialContext.java:438)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at javax.naming.InitialContext.lookup(InitialContext.java:417)
at com.keystone.test.User.getDatabaseConnection(User.java:156)
答案

创建JDBC连接池是不够的,您应该:

1)在“JDBC资源”部分中,创建使用池的资源

2)为该资源提供JNDI名称

3)在代码中查找该名称

(参见Payara/GlassFish DataSource JNDI Lookup ReferenceJDBC Connection Pool for GlassFish and Payara Java Application Servers

以上是关于JDBC连接池设置无法在Glassfish5上运行的主要内容,如果未能解决你的问题,请参考以下文章

在 Tomcat 7 上设置 SQL Server JDBC 连接池和资源

如何重置 JDBC 连接池

数据源连接池未关闭的问题 Could not open JDBC Connection for transaction

我可以将锁定模式设置为在 Informix - JDBC - tomcat 连接池中等待吗?

为啥在部署时验证 Java JDBC 连接池

jdbc连接池c3p0/dbcp强制连接超过设置时间后失效