Tomcat и JMeter генерируют ошибки HTTP 404
-
13-09-2019 - |
Вопрос
Я полный новичок в работе с JMeter.Я пытаюсь использовать JMeter для подключения к веб-приложению, развернутому в Tomcat, чтобы имитировать небольшое количество пользователей, входящих в систему и просматривающих страницу.
Когда я запустил план тестирования, журнал JMeter показал серию сообщений HTTP 404, указывающих на то, что где-то возникла проблема со связью.
По следующей ссылке показаны значения HTTP для плана тестирования по умолчанию:
альтернативный текст http://www.dcs.bbk.ac.uk /~martin/загружает/HTTP_Defaults.PNG
С двумя простыми HTTP-запросами для выполнения.
Первый запрос должен позволить пользователям войти в систему:
альтернативный текст http://www.dcs.bbk.ac.uk/~martin/загружает/Login.PNG
И второй запрос должен позволять вновь вошедшим в систему пользователям просматривать страницу:
альтернативный текст http://www.dcs.bbk.ac.uk/~martin/загружает/Просмотр.PNG
Но, как я уже сказал, все, что я получил в журналах JMeter, были сообщения HTTP 404:
2009/09/23 15:10:43 INFO - jmeter.protocol.http.sampler.HTTPSampler: Error Response Code: 404
Tomcat запущен во время тестирования, и в плане тестирования у меня также есть HTTP Cookie Manager, для которого установлено значение "по умолчанию".
Когда мое приложение запускается под Tomcat в тестовом режиме, его URL-адрес http://localhost:8080/myDataSharer
и я пытаюсь заставить JMeter отразить это.
Любая помощь была бы приветствована, поскольку я не могу понять, почему JMeter и Tomcat не разговаривают друг с другом.
Спасибо
Мартин
Решение
Тот самый путь в Значения по умолчанию для HTTP-запроса не добавляется в начале путь в HTTP-запрос.Добавьте корень контекста Хранитель myDataSharer к тропинке в HTTP-запрос.
Если вы не хотите повторять это повсюду, есть Элемент конфигурации где вы можете определить свойства, а затем ссылаться на них следующим образом ${моя собственность}.
Также вы должны добавить элемент, который показывает данные запроса и ответа, я думаю, он называется Дерево результатов или что-то в этом роде.
Правка 1: Еще одна вещь, которая выглядит необычной, - это путь запроса на вход в систему.Это правильный URL-адрес?Разве так не должно быть j_acegi_security_check
?Это тот URL-адрес, который появляется в действии формы входа в систему?
Правка 2: В Tomcat есть пример приложения, используемого для тестирования безопасности:
http://example.com:8080/examples/jsp/security/protected/login.jsp
Пользователи находятся в conf/tomcat-users.xml.Добавьте один из них с ролью: роль 1 вот так:
<role rolename="role1"/>
<user username="test" password="test" roles="role1"/>
Запустите сервер, и вы сможете войти в систему.Тогда попробуйте вот это План тестирования JMeter:
<jmeterTestPlan version="1.2" properties="1.8">
<hashTree>
<TestPlan guiclass="TestPlanGui" testclass="TestPlan" testname="Plan de Pruebas" enabled="true">
<boolProp name="TestPlan.functional_mode">false</boolProp>
<stringProp name="TestPlan.comments"></stringProp>
<stringProp name="TestPlan.user_define_classpath"></stringProp>
<boolProp name="TestPlan.serialize_threadgroups">false</boolProp>
<elementProp name="TestPlan.user_defined_variables" elementType="Arguments" guiclass="ArgumentsPanel" testclass="Arguments" testname="User Defined Variables" enabled="true">
<collectionProp name="Arguments.arguments"/>
</elementProp>
</TestPlan>
<hashTree>
<ThreadGroup guiclass="ThreadGroupGui" testclass="ThreadGroup" testname="Grupo de Hilos" enabled="true">
<boolProp name="ThreadGroup.scheduler">false</boolProp>
<stringProp name="ThreadGroup.num_threads">1</stringProp>
<stringProp name="ThreadGroup.duration"></stringProp>
<stringProp name="ThreadGroup.delay"></stringProp>
<longProp name="ThreadGroup.start_time">1157555458000</longProp>
<stringProp name="ThreadGroup.on_sample_error">stoptest</stringProp>
<stringProp name="ThreadGroup.ramp_time">0</stringProp>
<elementProp name="ThreadGroup.main_controller" elementType="LoopController" guiclass="LoopControlPanel" testclass="LoopController" testname="Loop Controller" enabled="true">
<stringProp name="LoopController.loops">1</stringProp>
<boolProp name="LoopController.continue_forever">false</boolProp>
</elementProp>
<longProp name="ThreadGroup.end_time">1157555458000</longProp>
</ThreadGroup>
<hashTree>
<CookieManager guiclass="CookiePanel" testclass="CookieManager" testname="Gestor de Cookies HTTP" enabled="true">
<boolProp name="CookieManager.clearEachIteration">false</boolProp>
<collectionProp name="CookieManager.cookies"/>
</CookieManager>
<hashTree/>
<HTTPSampler guiclass="HttpTestSampleGui" testclass="HTTPSampler" testname="Petición HTTP" enabled="true">
<stringProp name="HTTPSampler.domain">localhost</stringProp>
<stringProp name="HTTPSampler.FILE_NAME"></stringProp>
<stringProp name="HTTPSampler.path">/examples/jsp/security/protected/login.jsp</stringProp>
<stringProp name="HTTPSampler.method">GET</stringProp>
<elementProp name="HTTPsampler.Arguments" elementType="Arguments" guiclass="HTTPArgumentsPanel" testclass="Arguments" testname="User Defined Variables" enabled="true">
<collectionProp name="Arguments.arguments"/>
</elementProp>
<stringProp name="HTTPSampler.FILE_FIELD"></stringProp>
<stringProp name="HTTPSampler.mimetype"></stringProp>
<boolProp name="HTTPSampler.auto_redirects">false</boolProp>
<boolProp name="HTTPSampler.follow_redirects">true</boolProp>
<stringProp name="HTTPSampler.port">8080</stringProp>
<boolProp name="HTTPSampler.use_keepalive">true</boolProp>
<stringProp name="HTTPSampler.monitor">false</stringProp>
<stringProp name="HTTPSampler.protocol"></stringProp>
</HTTPSampler>
<hashTree/>
<HTTPSampler guiclass="HttpTestSampleGui" testclass="HTTPSampler" testname="Petición HTTP" enabled="true">
<stringProp name="HTTPSampler.domain">localhost</stringProp>
<stringProp name="HTTPSampler.FILE_NAME"></stringProp>
<stringProp name="HTTPSampler.path">/examples/jsp/security/protected/j_security_check</stringProp>
<stringProp name="HTTPSampler.method">POST</stringProp>
<elementProp name="HTTPsampler.Arguments" elementType="Arguments" guiclass="HTTPArgumentsPanel" testclass="Arguments" testname="User Defined Variables" enabled="true">
<collectionProp name="Arguments.arguments">
<elementProp name="" elementType="HTTPArgument">
<boolProp name="HTTPArgument.use_equals">true</boolProp>
<boolProp name="HTTPArgument.always_encode">false</boolProp>
<stringProp name="Argument.name">j_username</stringProp>
<stringProp name="Argument.value">test</stringProp>
<stringProp name="Argument.metadata">=</stringProp>
</elementProp>
<elementProp name="" elementType="HTTPArgument">
<boolProp name="HTTPArgument.use_equals">true</boolProp>
<boolProp name="HTTPArgument.always_encode">false</boolProp>
<stringProp name="Argument.name">j_password</stringProp>
<stringProp name="Argument.value">test</stringProp>
<stringProp name="Argument.metadata">=</stringProp>
</elementProp>
</collectionProp>
</elementProp>
<stringProp name="HTTPSampler.FILE_FIELD"></stringProp>
<stringProp name="HTTPSampler.mimetype"></stringProp>
<boolProp name="HTTPSampler.auto_redirects">true</boolProp>
<boolProp name="HTTPSampler.follow_redirects">true</boolProp>
<stringProp name="HTTPSampler.port">8080</stringProp>
<boolProp name="HTTPSampler.use_keepalive">true</boolProp>
<stringProp name="HTTPSampler.monitor">false</stringProp>
<stringProp name="HTTPSampler.protocol">http</stringProp>
</HTTPSampler>
<hashTree/>
<ResultCollector guiclass="ViewResultsFullVisualizer" testclass="ResultCollector" testname="Ver Árbol de Resultados" enabled="true">
<objProp>
<value class="SampleSaveConfiguration">
<time>true</time>
<latency>true</latency>
<timestamp>true</timestamp>
<success>true</success>
<label>true</label>
<code>true</code>
<message>true</message>
<threadName>true</threadName>
<dataType>true</dataType>
<encoding>false</encoding>
<assertions>true</assertions>
<subresults>true</subresults>
<responseData>false</responseData>
<samplerData>false</samplerData>
<xml>false</xml>
<fieldNames>false</fieldNames>
<responseHeaders>false</responseHeaders>
<requestHeaders>false</requestHeaders>
<responseDataOnError>false</responseDataOnError>
<saveAssertionResultsFailureMessage>false</saveAssertionResultsFailureMessage>
<assertionsResultsToSave>0</assertionsResultsToSave>
</value>
<name>saveConfig</name>
</objProp>
<stringProp name="filename"></stringProp>
<boolProp name="ResultCollector.error_logging">false</boolProp>
</ResultCollector>
<hashTree/>
</hashTree>
</hashTree>
</hashTree>
</jmeterTestPlan>
Посмотрите, что я добавил дополнительный запрос перед входом в систему, чтобы получить файл cookie.Если вы этого не сделаете, войти в систему с кодом 408 не удастся.
Если вы заставите это сработать, то ваше приложение можно будет протестировать таким же образом.
Другие советы
Наконец, у меня эта штука заработала - это был случай изменения автоматического перенаправления на следование перенаправлениям в запросах.Спасибо Родригоапу за помощь