Профилирование приложения Tomcat с помощью VisualVM

StackOverflow https://stackoverflow.com/questions/1890431

  •  19-09-2019
  •  | 
  •  

Вопрос

Я хотел бы профилировать приложение, работающее на Tomcat, с помощью инструмента VisualVM.К сожалению, когда я говорю VisualVM профилировать Tomcat, Tomcat распечатывает пару сообщений, указывающих, что он подключается к инструменту профилирования, а затем просто завершает работу.

Подробности…

Я использую Windows XP, Tomcat 6, VisualVM 1.2.1 и JDK 1.6.0_11.

  1. В Visual VM я щелкаю правой кнопкой мыши приложение Tomcat и выбираю «Профиль».
  2. На вкладке «Профилировщик» я нажимаю кнопку «Память» (или кнопку «ЦП»).
  3. Томкэт выходит

Обратите внимание: если я щелкну правой кнопкой мыши по приложению Tomcat и выберу «Дамп кучи», похоже, все будет работать нормально.

Это было полезно?

Решение

У меня есть VisualVM профилирование работы с моим Tomcat приложение сейчас.Мне нужно было добавить следующие параметры в автозагрузку Tomcat:

-Dcom.sun.management.jmxremote.port=8086
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=false

Вот хорошая статья по мониторингу Tomcat с VisualVM.

Другие советы

Да, мы профилируем приложения Tomcat.

Идти к catalina.bat или catalina.sh и это для твоего JAVA_OPTS (Я использую Tomcat 6.0.16):

-Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.port=9090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false

Твой JAVA_OPTS должно выглядеть так

set JAVA_OPTS=%JAVA_OPTS% -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties" -Dcom.sun.management.jmxremote=true -Dcom.sun.management.jmxremote.port=9090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false

Обновлено после комментария Райана о том, что лучше использовать setenv.sh.Это мое setenv.sh для JDK 8.Не хватает некоторых других настроек, но для начала неплохо.

SUN_JVM_OPTS="
    -server \
    -XX:MaxMetaspaceSize=3G \
    -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled \
    -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 \
    -XX:+ScavengeBeforeFullGC -XX:+CMSScavengeBeforeRemark \
    -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=3 -XX:GCLogFileSize=2M \
    -XX:+HeapDumpOnOutOfMemoryError \
    -Dsun.net.inetaddr.ttl=60 \
    -Dcom.sun.management.jmxremote  \
    -Dcom.sun.management.jmxremote.port=8480 \
    -Dcom.sun.management.jmxremote.authenticate=false \
    -Dcom.sun.management.jmxremote.ssl=false"


# Set custom application options here
APPLICATION_OPTS="-Dlog4j.configurationFile=patht-to-log/log4j2.xml -Dlog4j.debug=true "

JVM_OPTS="$GENERAL_JVM_OPTS $SUN_JVM_OPTS"
CATALINA_OPTS="$JVM_OPTS $APPLICATION_OPTS"
echo "Tomcat started with settings "$CATALINA_OPTS

Как только вы уроните setenv.sh в каталоге bin вы можете увидеть изменения в консоли при запуске.

Вот еще одно пошаговое руководство по профилированию приложений Tomcat с помощью Visual VM:Устранение проблем с производительностью приложений с помощью Visual VM

Я использую Tomcat 7, и для полной конфигурации требуется больше параметров.

-Dcom.sun.management.jmxremote=true 
-Dcom.sun.management.jmxremote.port=9090 # port to connect JMX 
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=false
-Djava.rmi.server.hostname=50.112.22.47" # IP of the server running tomcat (it is necessary)

источник: http://blog.markshead.com/1129/connecting-visual-vm-to-tomcat-7/

Все, что вам нужно сделать, это установить следующие параметры виртуальной машины:

-XX:+UnlockCommercialFeatures -XX:+FlightRecorder -XX:+UnlockDiagnosticVMOptions -XX:+DebugNonSafepoints -XX:FlightRecorderOptions=stackeepeep=512

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top