http服务器 性能测试,HTTP服务 性能测试

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的方式保存,类似这样

a32c43bc5c4d?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

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: 超时的时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值