Настройка JDBC Connection Pool не работает на Glassfish5 - PullRequest
1 голос
/ 22 марта 2019

В настоящее время я новичок в работе с сервером приложений 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)

1 Ответ

0 голосов
/ 22 марта 2019

Создание пула соединений JDBC недостаточно, вам следует:

1) В разделе «Ресурсы JDBC» создать ресурс, который использует ваш пул

2) Дать имя JNDIк этому ресурсу

3) Найдите это имя в своем коде

(ср. Справочник по поиску JNDI источника данных Payara / GlassFish и Пул соединений JDBC для GlassFish и PayaraСерверы приложений Java )

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...