Невозможно подключиться к базе данных Oracle с помощью ojdbc8 после обновления Java с 8u144 - любое обновление после и с 8u171 включительно

2

Я пытался обновить версию Java (в настоящее время 8u144), используемую в приложении, подключающемся к базе данных Oracle 12.2 с помощью ojdbc8. Моя последняя попытка обновления до 8u201 не удалась со следующей ошибкой:

Exception in thread "main" java.lang.NullPointerException
at oracle.net.jndi.JndiAttrs.getAttrs(JndiAttrs.java:215)
at oracle.net.resolver.AddrResolution.<init>(AddrResolution.java:237)
at oracle.net.ns.NSProtocol.connect(NSProtocol.java:233)
at oracle.jdbc.driver.T4CConnection.connect(T4CConnection.java:1438)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:518)
at oracle.jdbc.driver.PhysicalConnection.connect(PhysicalConnection.java:688)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:39)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:691)
at oracle.jdbc.pool.OracleDataSource.getPhysicalConnection(OracleDataSource.java:384)
at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java:273)
at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java:198)
at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java:176)
at Main.main(Main.java:22)

Я использую URL-адрес LDAP с поддерживаемым и задокументированным синтаксисом, подобным следующему:

"jdbc:oracle:thin:@ldaps://ldap.example.com:7777/sales,cn=OracleContext,dc=com"

Хотя мой вопрос похож на следующий, я не использую Hibernate, и, похоже, этот вопрос не отвечает и не решает, что может быть основной проблемой.

Невозможно получить соединение с БД после обновления Java 8

Чтобы упростить все, я сократил свои тесты до простого проекта, использующего только ojdbc8 и что-то вроде следующего:

    String url = "jdbc:oracle:thin:@ldaps://....";
    OracleDataSource ods = new OracleDataSource();
    ods.setUser("indiana");
    ods.setPassword("thedoctor");
    ods.setURL(url);

    Connection conn = ods.getConnection();
    PreparedStatement st = conn.prepareStatement("select * from world where temple = 'doom'");

    ResultSet rs = st.executeQuery();
    while(rs.next()) {
        System.out.println(rs.getString("last"));
    }

Если я переключаю Java на 8u144, используя точно такой же код и конфигурацию, вышеописанное работает просто отлично. Я в недоумении...

ОБНОВЛЕНИЕ Я немного сузил проблему и обнаружил, что разрыв происходит в Java 8u171. Я просматриваю заметки о выпуске для этой версии и все остальное, что могу найти сейчас.

  • 0
    Вы пытались просмотреть примечания к выпуску этих обновлений, чтобы увидеть, были ли внесены какие-либо изменения?
  • 0
    Спасибо за предложение. После дополнительного тестирования я сузил проблему до перерыва в 8u171. Я смотрю на эти заметки о выпуске сейчас.
Показать ещё 4 комментария
Теги:
java-8
jdbc
ojdbc

1 ответ

0

Похоже, SSL рукопожатие не удается при создании соединения LDAPS. Запуск тестовой программы с опцией java net debugging поможет проанализировать проблему. Добавьте эту опцию -Djavax.net.debug = all для запуска вашей тестовой программы, и выходные данные отладки будут содержать журналы отладки SSL, которые будут полезны для определения причины. JDK 8u171 имеет некоторые изменения, связанные с безопасностью.

(SSL Debug :: https://docs.oracle.com/javase/7/docs/technotes/guides/security/jsse/ReadDebug.html)

Ещё вопросы

Сообщество Overcoder
Наверх
Меню