JVM JMeter дает сбой через 10 минут
Я использую JMeter с 10 рабами. После выполнения в течение 10 минут Java вылетает:
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x0000000051c39ea0, pid=2488, tid=0x0000000000000ac0
#
# JRE version: Java(TM) SE Runtime Environment (8.0_181-b13) (build 1.8.0_181-b13)
# Java VM: Java HotSpot(TM) 64-Bit Server VM (25.181-b13 mixed mode windows-amd64 compressed oops)
# Problematic frame:
# V [jvm.dll+0x69ea0]
#
# Core dump written. Default location: C:\apache-jmeter-3.1\bin\hs_err_pid2488.mdmp
#
# If you would like to submit a bug report, please visit:
# http://bugreport.java.com/bugreport/crash.jsp
#
VM Arguments:
jvm_args: -XX:+HeapDumpOnOutOfMemoryError -Xms512m -Xmx3276m -XX:NewSize=128m -XX:MaxNewSize=128m -XX:SurvivorRatio=8 -XX:TargetSurvivorRatio=50 -XX:MaxTenuringThreshold=2 -XX:+CMSClassUnloadingEnabled
java_command: ApacheJMeter.jar
java_class_path (initial): ApacheJMeter.jar
Launcher Type: SUN_STANDARD
Environment Variables:
PATH=C:\Program Files (x86)\Common Files\Oracle\Java\javapath;C:\ProgramData\Oracle\Java\javapath;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;C:\Program Files\Amazon\cfn-bootstrap\
USERNAME=XXX
OS=Windows_NT
PROCESSOR_IDENTIFIER=Intel64 Family 6 Model 85 Stepping 4, GenuineIntel
Недавно мне пришлось увеличить размер кучи Java для всех ведомых и серверных компьютеров из-за OutOfMemoryError. все 10 подчиненных устройств имеют 4 ГБ ОЗУ, а серверная машина имеет 16 ГБ ОЗУ. Текущие настройки JMeter: HEAP = -Xms512m -Xmx3276m
2 ответа
Вы работаете с Java 8, но все еще используете старую версию JMeter 3.1,
Пожалуйста, попробуйте использовать последнюю версию 5.0, которая является первой из перечисленных в рекомендациях JMeter, а также для вашей проблемы сократите как можно больше ресурсов:
- Используйте режим без графического интерфейса: jmeter -n -t test.jmx -l test.jtl
- Используйте как можно меньше слушателей; При использовании флага -l, как указано выше, все они могут быть удалены или отключены.
- Не используйте прослушиватели "Просмотр дерева результатов" или "Просмотр результатов в таблице" во время нагрузочного теста, используйте их только на этапе создания сценариев для отладки сценариев.
- Вместо того, чтобы использовать много похожих сэмплеров, используйте один и тот же сэмплер в цикле и используйте переменные (набор данных CSV) для изменения сэмпла. [Включить контроллер здесь не помогает, так как он добавляет все тестовые элементы в файле в план тестирования.]
- Не используйте функциональный режим
- Используйте вывод CSV, а не XML
- Сохраняйте только те данные, которые вам нужны
- Используйте как можно меньше утверждений. Используйте наиболее эффективный язык сценариев (см. Раздел JSR223).
Это не сбой JMeter, а сбой JVM.
Ваша конфигурация имеет много проблем:
У вас есть это:
-Xms512m -Xmx3276m -XX: NewSize = 128 м. -XX:MaxNewSize=128 м.
Удалите их, так как ваши настройки неверны:
-XX: NewSize = 128 м. -XX:MaxNewSize=128 м.
Также проверьте, используете ли вы 10 ведомых на той же машине, что:
(куча + размер метапространства + количество потоков x размер стека) x 10 + 300 м <объем памяти компьютера
Вы говорите, что у вас 5 потоков на одно ведомое устройство, зачем использовать распределенное тестирование для такого небольшого числа ведомых устройств? JMeter способен без проблем выполнять 1000 потоков на 1 средней машине.
Наконец, обновите свой jmeter очень старую версию.