Jmeter не GUI режим CSV отчет не показывает задержку - PullRequest
0 голосов
/ 09 апреля 2020

Я пытаюсь получить отчет jmeter html для передачи файлов по протоколу SFTP. Я использую плагин SSH SFTP Protocol и добавил Simple Data Writer к этой группе потоков.

Я создал свой собственный сервер sftp, используя Apache MINA. Скрипт Jmeter попадет на сервер, который я создал, и загрузит файл.

Параметры скрипта:

  • Группа потоков - 250
  • Период наращивания - 50
  • L oop Количество - 1

После запуска сценария в режиме не GUI с именем nohup sh jmeter.sh -n -t Singlepart_MultipleThread_RampUp.jmx -l Singlepart_MultipleThread_RampUp.jtl. Я получаю сгенерированный CSV, который я преобразую в html команду отчета jmeter -g <csv> -o <destination_folder>.

Созданный отчет html показывает Latency vs Time и Latency vs Request как ноль, и даже отчет CSV показывает столбец задержки как ноль.

Ниже приведен мой файл user.properties

user.properties

# Latencies Over Time graph definition
jmeter.reportgenerator.graph.latenciesOverTime.classname=org.apache.jmeter.report.processor.graph.impl.LatencyOverTimeGraphConsumer
jmeter.reportgenerator.graph.latenciesOverTime.title=Latencies Over Time
jmeter.reportgenerator.graph.latenciesOverTime.property.set_granularity=${jmeter.reportgenerator.overall_granularity}

# Latencies Vs Request graph definition
jmeter.reportgenerator.graph.latencyVsRequest.classname=org.apache.jmeter.report.processor.graph.impl.LatencyVSRequestGraphConsumer
jmeter.reportgenerator.graph.latencyVsRequest.title=Latencies Vs Request
jmeter.reportgenerator.graph.latencyVsRequest.exclude_controllers=true
jmeter.reportgenerator.graph.latencyVsRequest.property.set_granularity=${jmeter.reportgenerator.overall_granularity}

jmeter.properties

#---------------------------------------------------------------------------
# Results file configuration
#---------------------------------------------------------------------------

# This section helps determine how result data will be saved.
# The commented out values are the defaults.

# legitimate values: xml, csv, db.  Only xml and csv are currently supported.
jmeter.save.saveservice.output_format=csv

# The below properties are true when field should be saved; false otherwise
#
# assertion_results_failure_message only affects CSV output
jmeter.save.saveservice.assertion_results_failure_message=true
#
# legitimate values: none, first, all
jmeter.save.saveservice.assertion_results=all
#
jmeter.save.saveservice.data_type=true
jmeter.save.saveservice.label=true
jmeter.save.saveservice.response_code=true
# response_data is not currently supported for CSV output
jmeter.save.saveservice.response_data=true
# Save ResponseData for failed samples
jmeter.save.saveservice.response_data.on_error=false
jmeter.save.saveservice.response_message=true
jmeter.save.saveservice.successful=true
jmeter.save.saveservice.thread_name=true
jmeter.save.saveservice.time=true
jmeter.save.saveservice.subresults=true
jmeter.save.saveservice.assertions=true
jmeter.save.saveservice.latency=true
# Only available with HttpClient4
#jmeter.save.saveservice.connect_time=true
jmeter.save.saveservice.samplerData=true
#jmeter.save.saveservice.responseHeaders=false
#jmeter.save.saveservice.requestHeaders=false
#jmeter.save.saveservice.encoding=false
jmeter.save.saveservice.bytes=true
# Only available with HttpClient4
jmeter.save.saveservice.sent_bytes=true
jmeter.save.saveservice.url=true
jmeter.save.saveservice.filename=false
jmeter.save.saveservice.hostname=false
jmeter.save.saveservice.thread_counts=true
jmeter.save.saveservice.sample_count=false
jmeter.save.saveservice.idle_time=true

# Timestamp format - this only affects CSV output files
# legitimate values: none, ms, or a format suitable for SimpleDateFormat
#jmeter.save.saveservice.timestamp_format=ms
#jmeter.save.saveservice.timestamp_format=yyyy/MM/dd HH:mm:ss.SSS

# For use with Comma-separated value (CSV) files or other formats
# where the fields' values are separated by specified delimiters.
# Default:
#jmeter.save.saveservice.default_delimiter=,
# For TAB, one can use:
#jmeter.save.saveservice.default_delimiter=\t

# Only applies to CSV format files:
# Print field names as first line in CSV
#jmeter.save.saveservice.print_field_names=true

# Optional list of JMeter variable names whose values are to be saved in the result data files.
# Use commas to separate the names. For example:
#sample_variables=SESSION_ID,REFERENCE
# N.B. The current implementation saves the values in XML as attributes,
# so the names must be valid XML names.
# By default JMeter sends the variable to all servers
# to ensure that the correct data is available at the client.

# Optional xml processing instruction for line 2 of the file:
# Example:
#jmeter.save.saveservice.xml_pi=<?xml-stylesheet type="text/xsl" href="../extras/jmeter-results-detail-report.xsl"?>
# Default value:
#jmeter.save.saveservice.xml_pi=

# Prefix used to identify filenames that are relative to the current base
#jmeter.save.saveservice.base_prefix=~/

# AutoFlush on each line written in XML or CSV output
# Setting this to true will result in less test results data loss in case of Crash
# but with impact on performances, particularly for intensive tests (low or no pauses)
# Since JMeter 2.10, this is false by default
#jmeter.save.saveservice.autoflush=false

Таким образом, в основном возникает проблема в двух местах:

  1. Как получить значение задержки?
  2. Когда я предоставляю значение Ramp up как 1, скрипт с Thread Group =50 требуется около 16 секунд, чтобы завершить загрузку, тогда как если я даю Ramp up что-то, отличное от 1, например, 10, то сценарий заканчивается через 10 секунд, независимо от того, загружается файл или нет, и дает неопределенные результаты в html сообщите также.

Любая идея, как решить эту проблему. Или нужно сделать что-нибудь еще в сценарии.

1 Ответ

0 голосов
/ 13 апреля 2020
  1. Вы не можете, поскольку используемый вами плагин не вызывает SampleResult.setLatency () функция в любом месте

    enter image description here

    теоретически должно быть возможно запросить функциональность у разработчиков плагинов

  2. Настройка 10-секундного периода разгона для 50 виртуальных пользователей означает, что JMeter запускается с 1 виртуального пользователя и постепенно увеличивает нагрузку до 50 в течение 10 секунд. Убедитесь, что в группе потоков определено достаточное количество циклов, так как вы можете столкнуться с ситуацией, когда 1-й пользователь уже завершил загрузку файла и был прерван, а 2-й не нужно запускать, поэтому у вас есть максимум 1 параллелизм пользователя (это можно проверить с помощью активных потоков с течением времени слушатель). См. Результаты теста JMeter: почему фактическое число пользователей меньше ожидаемого для более подробного объяснения, если это необходимо.

...