基本语法
// 定义一个httpConf
var httpConf = http
// 定义一个http请求
val search = exec(http("Home").get("/"))
.pause(7)
.exec(http("Search").get("/computers?f=macbook"))
.pause(2)
.exec(http("Select").get("/computers/6"))
.pause(3)
// 定义一个场景
val scn = scenario("Scenario Name").exec(search)
// 设置场景并发用户数,执行场景
setUp(scn.inject(atOnceUsers(10)).protocols(httpConf))
// csv使用,可以是random还可以是
val feeder = csv("search.csv").random
// 使用之前先调用feed(feeder),
val search = feed(feeder)
.exec(http("Home").get("/${columnname}"))
.pause(7)
// csv数据格式
// 循环repeat
val search = repeat(1000) {
feed(feeder)
.exec(http("Home").get("/${columnname}"))
.pause(7)
}
// 检查点
val search = feed(feeder)
.exec(http("Home").get("/${columnname}"))
.pause(7)
.check()
General
####Concepts:
#####Virtual User:
一般的性能测试软件通过threads来实现vu,gatling通过messages来实现,可以更好地实现上千的并发用户
#####Scenario:
场景,代表着用户的行为,虚拟用户按照场景运行
创建一个场景:
scenario(“My Scenario”)
exec用来执行一个action,也可以执行一个Lambda表达式(就是匿名函数)
e`g:
exec(http("Get Homepage").get("http://github.com/gatling/gatling"))
exec { session => session.set("foo", "bar") }
exec { session =>
// displays the content of the session in the console (debugging only)
println(session)
// return the original session
session
}
#####Simulation:
仿真、模拟,描述了一个性能测试的过程:执行哪些场景?怎么加载虚拟用户数?等
val stdUser = scenario("Standard User") // etc..
val admUser = scenario("Admin User") // etc..
val advUser = scenario("Advanced User") // etc..
setUp(
stdUser.inject(atOnceUsers(2000)),
admUser.inject(nothingFor(60 seconds), rampUsers(5) over (400 seconds)),
advUser.inject(rampUsers(500) over (200 seconds))
)
#####Session:
每个虚拟用户都是一个单独的会话
#####Feeders:
数据配置文件
#####Checks:
#####Assertions:
#####Assertions:
脚本模板
package computerdatabase
import io.gatling.core.Predef._
import io.gatling.http.Predef._
import scala.concurrent.duration._
object Test1 {
val test1 = exec(http("test1").get("http://172.18.84.135:8080/test/index.jsp"))
}
object Test2 {
val test2 = exec(http("test2").get("http://172.18.84.135:8080/test/index.jsp"))
}
object Test3 {
val test3 = exec(http("test3").get("http://172.18.84.135:8080/test/index.jsp"))
}
object Test4 {
val test4 = exec(http("test4").get("http://172.18.84.135:8080/test/index.jsp"))
}
class MyBasicSimulation extends Simulation {
var httpconf = http.connectionHeader("keep-alive")
val scn = scenario("scenario").during(2 minutes){
group("mygroup1"){
// 以下两种写法均可
// exec(Test1.test1).exec(Test2.test2).exec(Test3.test3).exec(Test4.test4)
exec(Test1.test1, Test2.test2, Test3.test3, Test4.test4)
}
}
setUp(scn.inject(atOnceUsers(1))).protocols(httpconf)
}