0

我想在我的 mac (Mac OS 10.8.1) 上使用 Gatling 2.0.0-M3 在我的服务器上执行负载测试。

我有两个 REST 服务要测试:版本和健康检查。这些服务不连接任何数据库,相对简单。他们在正文中返回一些文本。当我尝试一次加载测试一项服务时,响应时间似乎是正确的(小于 10 毫秒)。但是,当我混合调用这些服务时,响应时间超过 12,000 毫秒。

这是我为测试服务而编写的代码:

class MonitoringServices extends Simulation {
    val httpProtocol = http.baseURL("http://10.12.84.19:5000")
                           .acceptHeader("text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8")
                           .acceptEncodingHeader("gzip, deflate")
                           .acceptLanguageHeader("fr,fr-fr;q=0.8,en-us;q=0.5,en;q=0.3")
                           .connection("keep-alive")
                           .userAgentHeader("Mozilla/5.0 (Windows NT 6.1; WOW64; rv:24.0) Gecko/20100101 Firefox/24.0")

    val headers_1 = Map(
                        "Accept" -> "application/json;q=0.9,*/*;q=0.8",
                        "Accept-Charset" -> "ISO-8859-1,utf-8;q=0.7,*;q=0.7",
                        "Cache-Control" -> "max-age=0"
    )
    val scn1 = scenario("Monitoring services: version")
                  .exec(http("version")
                  .get("/mood-engine/v1/version")
                  .headers(headers_1)
                  .check(status.is(200))
               )

    val scn2 = scenario("Monitoring services: health-check")
                   .exec(http("version")
                   .get("/mood-engine/v1/health-check")
                   .headers(headers_1)
                   .check(status.is(200))
               )

    setUp(
        scn1.inject(
            atOnce(1 user),
            constantRate(1 usersPerSec) during (10 seconds)
        ),
        scn2.inject(
            atOnce(1 user),
            constantRate(1 usersPerSec) during (10 seconds)
        )
    ).protocols(httpProtocol)
     .assertions(global.responseTime.max.lessThan(350))
}

你有什么线索吗?

4

1 回答 1

0

问题很可能出在您的测试系统中(死锁?)。你能监控服务器端吗?如果它在 JVM 上运行,您可以尝试使用 VisualVM 或 YourKit 并查看您的线程在做什么。

PS:请升级到 M3a,这是我们在 M3 之后不久发布的修复。

于 2013-09-20T09:46:10.200 回答