утечка памяти в драйвере weblogic rmi - PullRequest
0 голосов
/ 12 февраля 2019

У нас возникла проблема утечки памяти после того, как мы начали использовать существующий источник данных Weblogic из наших автономных приложений.Автономные приложения и WL Datasource не лежат на одном сервере.Мы извлекаем источник данных с JNDI по протоколу t3.

Мы использовали подход, описанный ниже.https://docs.oracle.com/cd/E13222_01/wls/docs51/classdocs/API_jndi.html

87% кучи выделяется weblogic/jdbc/rmi/internal/StructImpl_oracle_sql_STRUCT объектами.Эти объекты находятся в пакете RMI (удаленный вызов метода), и сама проблема начала появляться после этого удаленного использования.Поскольку эти две вещи произошли одновременно, мы подозреваем, что если мы сделали что-то не так в процессе использования удаленного источника данных.

Все работает нормально, но мы перезапускаем узлы каждые 2-3 дня и начинаемстало бременем для нас.

Что может быть причиной этой утечки памяти?Должны ли мы что-либо изменить в свойствах источника данных или нам нужно передать дополнительные параметры JVM?

Вот снимок нашей кучи

enter image description here

Вот свойства веблогии.

Weblogic major version 10.3.6.0 
Patch level: 10.3.6.0.181016 (October 2018 PSU - GENM)
Java version: Java HotSpot(TM) 64-Bit Server VM (build 20.45-b01, mixed mode) - 1.6.0_45
MEM_ARGS="-Xms4096m -Xmx6144m -Xmn1024m -XX:SurvivorRatio=8 -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:PermSize=256m -XX:MaxPermSi
ze=512m -verbosegc -XX:+PrintGCTimeStamps -XX:+PrintGCDetails -Xloggc:${LOGDIR}/GC_logs.${SERVER_NAME} -XX:+UseGCLogFileRotation -XX
:+PrintGCDateStamps -XX:NumberOfGCLogFiles=100 -XX:GCLogFileSize=512M"
--- EXTRA JAVA OPTIONS
-DASA_MARK=ASA_VERSION_2016.02.17"
-Dweblogic.management.server=${ADMIN_URL}"
-DHostName_WLSName=${value_hostname}-${WLS_NAME}"
-Dweblogic.system.BootIdentityFile=${DOMAIN_HOME}/boot.properties"
-Dweblogic.rjvm.enableprotocolswitch=true"
-Djava.net.preferIPv4Stack=true"

Вот свойства нашего автономного приложения

[wlsadmin@machine1 cfg]$ /usr/java/jdk1.6.0_26/bin/java -version
java version "1.6.0_26"
Java(TM) SE Runtime Environment (build 1.6.0_26-b03)
Java HotSpot(TM) 64-Bit Server VM (build 20.1-b02, mixed mode)
CLASSPATH=$CLASSPATH:$HOME/lib/wlfullclient.jar
[wlsadmin@machine1 META-INF]$ more MANIFEST.MF 
Manifest-Version: 1.0
Implementation-Vendor: Oracle Corp.
Implementation-Title: JDK 1.6 Client jar for WebLogic Server 10.3  Tue
  Nov 15 08:52:36 PST 2011 1441050 
Implementation-Version: 10.3.6.0
CLASSPATH=$CLASSPATH:$HOME/lib/ojdbc5.jar
[wlsadmin@machine1 META-INF]$ more MANIFEST.MF 
Manifest-Version: 1.0
Specification-Title: "Oracle Globalization Development Kit"
Class-Path: orai18n-mapping.jar orai18n-utility.jar orai18n-collation.
jar orai18n-translation.jar orai18n-net.jar orai18n-servlet.jar orai1
8n-lcsd.jar orai18n-tools.jar gdk_custom.jar
Created-By: 1.5.0_07 (Sun Microsystems Inc.)
Main-Class: oracle.i18n.util.GDKOracleMetaData
Implementation-Title: "orai18n.jar archives"
Specification-Vendor: "Oracle Corporation"
Specification-Version: "Oracle Globalization Development Kit - 11.2.0.
1.0 - Production, Build : 11"
Implementation-Version: "Oracle Globalization Development Kit - 

-Xms64m -Xmx256m 

1 Ответ

0 голосов
/ 20 февраля 2019

Я не могу угадать, какие изменения вы можете внести в соответствующий код, но на основании описания утечки памяти - это связано с использованием не поточно-ориентированной хэш-карты.Это может помочь попробовать использовать ConcurrentHashMap.

Пожалуйста, проверьте эти ссылки для более подробной информации:

https://support.oracle.com/knowledge/Middleware/1966075_1.html

https://javaeesupportpatterns.blogspot.com/2011/11/hashmap-thread-safe-problem-case-study.html

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