美文网首页
HTTP服务 性能测试

HTTP服务 性能测试

作者: Ary_zz | 来源:发表于2019-01-14 20:43 被阅读0次

    2019-01-14

    之前提到的全文搜索包含2个部分,index、search,搜索服务上线后,需要对服务做一个并发性能测试,由于搜索服务依赖ES,因此测试变量里还包含ES的集群规模大小,搜索的数据范围

    主要使用的测试工具有2个

    gatling

    官网地址,这是一款国人开源的web压测工具,自带UI集成,使用方式比较繁琐,涉及图形化界面。。。

    作为一个程序猿,只需要关注如何用命令行操作。。

    具体方法就是下载brinary包以后,修改里面的测试脚本,然后执行bin/gatling.sh

    测试脚本的语言是scala,api使用看示例

    class BasicSimulation extends Simulation { // 3
    
      val httpProtocol = http // 4
        .baseUrl("http://computer-database.gatling.io") // 5
        .acceptHeader("text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8") // 6
        .doNotTrackHeader("1")
        .acceptLanguageHeader("en-US,en;q=0.5")
        .acceptEncodingHeader("gzip, deflate")
        .userAgentHeader("Mozilla/5.0 (Windows NT 5.1; rv:31.0) Gecko/20100101 Firefox/31.0")
    
      val scn = scenario("BasicSimulation") // 7
        .exec(http("request_1") // 8
          .get("/")) // 9
        .pause(5) // 10
    
      setUp( // 11
        scn.inject(atOnceUsers(1)) // 12
      ).protocols(httpProtocol) // 13
    }
    

    可以看到api提供了模拟请求头的方式,并且能够像pipeline一样写一串连续请求来模拟用户操作,并发的方式是修改 //12 处的用户数

    这个工具最好的一点在于能够根据测试结果自动生成可视化图表,以html的方式保存,类似这样


    charts-indicators.png

    wrk

    这是一个更加纯命令行的工具,没有漂亮的图表,但是很强大,主要参数一目了然,也可以用脚本模拟,语言是lua

    -c, --connections:  总的连接数(每个线程处理的连接数=总连接数/线程数)
    
    -d, --duration:        测试的持续时间,如2s(2second),2m(2minute),2h(hour)
    
    -t, --threads:         需要执行的线程总数
    
    -s, --script:          执行Lua脚本,这里写lua脚本的路径和名称,后面会给出案例
    
    -H, --header:      需要添加的头信息,注意header的语法,举例,-H “token: abcdef”,说明一下,token,冒号,空格,abcdefg(不要忘记空格,否则会报错的)。
    
    --latency:     显示延迟统计信息
    
    --timeout:     超时的时间
    

    相关文章

      网友评论

          本文标题:HTTP服务 性能测试

          本文链接:https://www.haomeiwen.com/subject/cnajdqtx.html