Не удалось сопоставить собственное выделение памяти (mmap) при использовании jdbc8.jar и клиента Oracle 18 - PullRequest
1 голос
/ 22 мая 2019

У меня есть Java-приложение, которое извлекает большой XML-файл из базы данных Oracle 11g Release 11.2.0.4.0 (с использованием Spring 4) и сохраняет их в файлах. У нас возникла проблема при извлечении данных, содержащих многобайтовые символы. В зависимости от того, где в xml находится многобайтовый код, он иногда делит мультибайт на 2 части. Похоже, проблема была в версии jdbc и установленном клиенте oracle. Поэтому мы перешли на клиент Oracle 18 и ojdb8.jar, оставив код без изменений. Многобайтовая проблема была решена, но теперь вместо этого у нас есть проблемы с памятью, которых раньше не было. Я получаю ошибку:

Недостаточно памяти для продолжения среды выполнения Java.

При выделении собственной памяти (mmap) не удалось сопоставить 256376832 байта для фиксации зарезервированной памяти.

Я поигрался с параметрами команды java, но безрезультатно. Это то, что я бегу: java -Dfile.encoding = UTF8 -Doracle.jdbc.timezoneAsRegion = false -Xmx10240m -XX: + HeapDumpOnOutOfMemoryError -XX: HeapDumpPath = / tmp -XX: NativeMemoryTracking = detail -XX: + Учебное ядро ​​-XT: НОТАЛИЯ-НОТАЛИЯ: -XNTXTXTX: +

Уменьшение Xmx до 512 м привело к исчерпанию кучи памяти.

Я контролировал память приложения, используя jcmd VM.native_memory baseline / summary.diff и GC.class_stats, и одним из крупнейших потребителей памяти являются объекты String. Я не смог разобраться в остальном.

sql: ВЫБЕРИТЕ XML_DATA ИЗ таблицы, где ....

Столбец xml_data определяется как: XML_DATA NOT NULL SYS.XMLTYPE ДВОЙНОЕ ХРАНИЛИЩЕ

Отображение этого в Java для oracle.xdb.XMLType:

public List<XMLType> extractXmlDataList(String sqlExtractionQuery, Key key) {
    MapSqlParameterSource namedSqlParams = createKeyParamMap(key);
    List<XMLType> dataList = namedParameterJdbcTemplate.queryForList(sqlExtractionQuery, namedSqlParams, XMLType.class);
    return dataList;
}


protected void extractXmlData(Key key) {
List<XMLType> xmlRecs = producerDao.extractXmlDataList(sqlExtractionQuery, patentKey);
    if (xmlRecs != null && xmlRecs.size() > 0) {
        for (XMLType xmlData : xmlRecs) {
            String xmlText = xmlData.getStringVal();
            //create nu.xom.Document
            Builder parser = new Builder();
            Document xmlDocument = parser.build(xmlText, null);
        }
    }       
}

Как переход на клиент Oracle 18 и jdbc8.jar может так сильно повлиять на потребление памяти?

1 Ответ

1 голос
/ 06 июня 2019

Проблема с памятью была решена с помощью xmlserialize, а не объекта Oracle Java XMLType. Все еще использую клиент Oracle 18 и ojdbc8.jar. Больше никаких проблем с многобайтовым разделением UTF8.

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