簡體   English   中英

JDBC連接池設置在Glassfish5上不起作用

[英]JDBC Connection Pool setup not working on Glassfish5

我目前是Glassfish應用程序服務器的新手,我一直在在線學習各種教程,以使用管理界面在服務器上設置JDBC連接池。

我可以看到創建的連接池與默認情況下在服務器上創建的兩個連接池一起列出,如下面的屏幕快照所示

在此處輸入圖片說明

我對這個設置執行了ping操作,以確保一切正常,但是,當我嘗試從下面的代碼列表中獲取與數據庫的連接時,

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)在您的代碼中查找該名稱

(請參閱用於GlassFish和Payara Java應用程序服務器的 Payara / GlassFish數據源JNDI查找參考JDBC連接池

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM