为何要写Gatling呢?网上已经有一些介绍Gatling的好文章了,好比两位TW同事的文章,能够看这里(我知道Gatling也是由于这位做者介绍的),还有这里。主要是由于最近在使用Gatling作压力测试,感受这个工具很是好用,因此想结合本身的使用状况也推荐一下。Gatling是基于scala写的一个开源的压力测试工具,它的特色是简单易用,测试报告简洁漂亮,api通俗易懂。html
JDK1.7
Gatling是基于jdk1.7开发的,因此还在用jdk1.6的同窗须要先下载jdk1.7,才能够启动Gatling。顺便说一下,JDK1.7之后确定是会替换JDK1.6的,但因为历史缘由(主要是JDK1.6用的人实在太多了,我想也是因为JDK1.7升级的太晚了)你们都不想升级,我也这也是JAVA走下坡路的缘由。java
Scala
前面讲过Gatling是用scala写的,像scala、groovy和clojuer都是基于jvm开发的一种语言,不只继承了java众多成熟的api和稳定的jvm,并且提供了更佳简洁易用的语法。基于某种语言的内核来从新设计一门新语言的这种作法,如今慢慢多了起来,这种作法的最大好处就是不用本身再从新设计编程语言底层相关的一些东西,并且可使用原有语言大量的成熟api,让新语言就只专一地实现本身的功能,从而使新的语言性能稳定,易用性更高,甚至能够吸引一些原有语言的开发人员。git
DSL
看过Galting的api的人就会发现,它的语法很像天然语言,好比测试一个get类型的http请求,它可能会这样写:github
1 2 |
exec(http("demo") .get("http://www.myweb.com/helloworld") |
是否是很容易懂,这种就是基于DSL来写的代码,关于DSL能够看这本书,这本书我还没怎么看,等看完了之后再作分享,DSL不仅仅只是把代码写得像天然语言那样简单。web
API
要想了解Gatling的各类api,这里推荐看Gatling源码里面的HttpCompileTest这个测试类,这里包含了http几乎全部的api使用示例。下面是截取的代码片断,所有代码能够看这里。编程
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
.group("C'est ici qu'on trouve des Poneys") { exec(http("Catégorie Poney").post("/") .param("baz", "${qix}") .multivaluedParam("foo", Seq("bar"))) .exec(http("Catégorie Poney").post("/").multivaluedParam("foo", "${bar}")) .exec(http("Catégorie Poney").get("/").queryParam("omg", "foo")) .exec(http("Catégorie Poney").get("/").queryParam("omg", "${foo}")) .exec(http("Catégorie Poney").get("/").queryParam("omg", session => "foo")) .exec(http("Catégorie Poney").get("/").multivaluedQueryParam("omg", List("foo"))) .exec(http("Catégorie Poney").get("/").multivaluedQueryParam("omg", "${foo}")) .exec(http("Catégorie Poney").get("/").multivaluedQueryParam("omg", List("foo"))) } .uniformRandomSwitch(exec(http("Catégorie Poney").get("/")), exec(http("Catégorie Licorne").get("/"))) .randomSwitch( 40d -> exec(http("Catégorie Poney").get("/")), 50d -> exec(http("Catégorie Licorne").get("/"))) .randomSwitch(40d -> exec(http("Catégorie Poney").get("/"))) .pause(pause2) |
这里说下randomSwitch这个方法,这个方法能够模拟负载均衡,好比上面40d和50d的两行代码,会有40%的概率执行上面一行代码,50%的概率执行下面一行代码。api
Question
若是看过上面的示例代码代码,还不知道具体的api怎么用,能够到google group上面的分组提问题,很快就有人回答你的问题。github上面的问题区是让开发提bug或者feature用的,因此尽可能不要在上面提问题。session
Report
下面是Gatling的报告截图,界面很漂亮,并且参数很齐全,包括所有的请求数,成功/失败的请求数,请求的最大/最小/平均响应时间等。负载均衡
Http & JMS
目前Gatling支持的协议很少,毕竟是一个轻量级的测试工具,目前只支持Http和JMS(之前用的时候还只是支持HTTP),随着Gatling的发展,之后确定会支持更多的协议。如今大部分的系统和应用都是提供http协议的api,因此基于http协议的测试也能知足大部分的测试场景了。dom