Профилирование приложения Tomcat с помощью VisualVM
Вопрос
Я хотел бы профилировать приложение, работающее на Tomcat, с помощью инструмента VisualVM.К сожалению, когда я говорю VisualVM профилировать Tomcat, Tomcat распечатывает пару сообщений, указывающих, что он подключается к инструменту профилирования, а затем просто завершает работу.
Подробности…
Я использую Windows XP, Tomcat 6, VisualVM 1.2.1 и JDK 1.6.0_11.
- В Visual VM я щелкаю правой кнопкой мыши приложение Tomcat и выбираю «Профиль».
- На вкладке «Профилировщик» я нажимаю кнопку «Память» (или кнопку «ЦП»).
- Томкэт выходит
Обратите внимание: если я щелкну правой кнопкой мыши по приложению 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