http - Tomcat 和 JMeter 生成 HTTP 404 错误

标签 http tomcat http-status-code-404 jmeter performance-testing

我是 JMeter 的新手。我正在尝试使用 JMeter 连接到部署在 Tomcat 中的 Web 应用程序,以模拟少量用户登录和浏览页面。

当我运行测试计划时,JMeter 日志显示了一系列 HTTP 404 消息,表明某处存在通信问题。

以下链接显示了测试计划的 HTTP 默认值:

alt text http://www.dcs.bbk.ac.uk/~martin/uploads/HTTP_Defaults.PNG

后面有两个简单的 HTTP 请求。

第一个请求应该允许用户登录:

alt text http://www.dcs.bbk.ac.uk/~martin/uploads/Login.PNG

第二个请求应该允许新登录的用户浏览页面:

alt text http://www.dcs.bbk.ac.uk/~martin/uploads/Browse.PNG

但是,正如我所说,我在 JMeter 日志中收到的只是 HTTP 404 消息:

2009/09/23 15:10:43 INFO  - jmeter.protocol.http.sampler.HTTPSampler: Error Response Code: 404 

Tomcat 在测试期间和测试计划中运行,我还将 HTTP Cookie 管理器设置为“默认”。

当我的应用程序在测试中在 Tomcat 下运行时,它的 URL 是 http://localhost:8080/myDataSharer,我试图让 JMeter 反射(reflect)这一点。

欢迎任何帮助,因为我不明白为什么 JMeter 和 Tomcat 不互相交谈。

谢谢

马丁

最佳答案

HTTP Request Defaults 中的path 未添加到HTTP Requestpath 的开头。将上下文根 myDataSharer 添加到 HTTP 请求 中的路径。
如果您不想在每个地方都重复它,有一个配置元素,您可以在其中定义属性并稍后像这样引用它${my.propertie}
您还应该添加一个显示请求和响应数据的元素,我认为它叫做 Result Tree 或类似的东西。

编辑 1: 另一件看起来很奇怪的事情是登录请求的路径。该网址是否正确?不应该是 j_acegi_security_check 吗?那是出现在登录表单操作中的 url 吗?

编辑 2:在 Tomcat 中有一个用于测试安全性的示例应用程序:
http://example.com:8080/examples/jsp/security/protected/login.jsp

用户在 conf/tomcat-users.xml 中。添加一个角色:role1,如下所示:

<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 代码。

如果你让它工作,那么你的应用程序可以用同样的方式进行测试。

关于http - Tomcat 和 JMeter 生成 HTTP 404 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1466391/

相关文章:

c - 在 HTTP 服务器中发出文件结束信号

tomcat - solrj 是否对内容进行编码?

asp.net - 如何创建自定义 404 页面并发送 404 消息?

jquery - 如何使用 jQuery $.ajax() 处理 404 错误

iphone - http GET 限制(iPhone)

http - 优雅关闭 node.JS HTTP 服务器

http - IBM Worklight HTTP 适配器 SOAP 响应 : XSL transformation failed

tomcat - 在 tomcat 上部署 Apache Solr 5.2.1

tomcat - Ubuntu 16.04 在 Netbeans 8.2 中添加 Tomcat9 - 错误 :The specified Server Location (Catalina Home) folder is not valid

php - 在 Magento 中捕获 404 的最佳方法是什么