SHIHUC

好记性不如烂笔头,还可以分享给别人看看! 专注基础算法,互联网架构,人工智能领域的技术实现和应用。
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

jenkins:应用篇(Gatling plugin的使用)

Posted on 2016-01-21 17:32  shihuc  阅读(4538)  评论(2编辑  收藏  举报

Jenkins的功能强大,在于它的插件式框架,能扩展功能,自动化当中,很容易想到的是对提交的新代码做测试,这里gatling主要是负责压力测试,也就是所谓的性能。关于gatling,可以参考我前面的博文。

 

在jenkins下,首先要安装gatling的插件,可以直接在Jenkins>Manage Jenkins>Manage Plugins>Available下点击安装,也可以在Advance里面通过上传安装。由于我这里两个浏览器设置的代理不同,在测试jenkins的浏览器中不能直接点击Available里面的gatling安装,网络无法联通。所以,我在另外一个带有FQ代理的浏览器中,先下载了gatling.hpi(我这里是1.1.1版本)插件文件到本地。再通过advance的tab下上传文件的方式进行安装。

按照上图,只需要关注红色框部分即可,其他就默认吧,点击submit,然后将jenkins重启,gatling plugin就安装好了。

 

现在可以看看jenkins下的gatling是如何集成在maven项目里,做一个自动化性能测试的。还是基于前面博文的项目mueas,由于之前,mueas项目下,没有gatling的支持。所以,要在mueas工程的pom文件添加依赖和plugin的配置。

下面先看看依赖的配置:

1     <!-- Add Gatling maven plugin to support gatling startup to test performance -->
2     <dependency>
3             <groupId>io.gatling.highcharts</groupId>
4             <artifactId>gatling-charts-highcharts</artifactId>
5             <version>2.1.6</version>
6     </dependency>        

再就是在pom文件的build部分添加plugin的配置:

 1 <build>
 2         <plugins>
 3             。。。。。  #此处是其他相关的plugin的内容,省略了
 4             <plugin>
 5                   <groupId>io.gatling</groupId>
 6                   <artifactId>gatling-maven-plugin</artifactId>
 7                   <version>2.1.6</version>
 8                   <configuration>  #此configuration部分的配置,要结合自己的项目的结构来填写信息
 9                       <configFolder>src/test/resources</configFolder>
10                       <dataFolder>src/test/resources/data</dataFolder>
11                       <resultsFolder>target/gatling/results</resultsFolder>
12                       <bodiesFolder>src/test/resources/bodies</bodiesFolder>
13                       <simulationsFolder>src/test/scala</simulationsFolder>
14                 </configuration>
15                   <executions>
16                     <execution>
17                       <id>execution-1</id>
18                       <goals>
19                         <goal>execute</goal>
20                       </goals>
21                       <configuration>
22                         <simulationClass>simple/MueasSimulation_Simple</simulationClass>
23                       </configuration>
24                     </execution>
25                     <!-- Here, can repeat the above execution segment to do another test -->
26                 </executions>
27             </plugin>
28         </plugins>
29     </build>

附带着将eclipse中maven工程的文件结构也展示一下:

 

由于gatling的压力测试脚本是基于scala语言写的,所以,目录中simulationFolder部分src/test/scala下面,是一个scala的程序。

 

那这里,看看这个scala脚本程序是什么样子吧,很简单:

 1 package simple
 2 
 3 import io.gatling.core.Predef._
 4 import io.gatling.http.Predef._
 5 import scala.concurrent.duration._
 6 
 7 class MueasSimulation extends Simulation{
 8   val httpConf = http.baseURL("http://localhost:8080")
 9   var scn = scenario("Search mueas home page")
10               .exec(http("Redirect Login").get("/").check(currentLocation.saveAs("post_url")))
11               .pause(10 seconds)
12               .exec(http("Try login").post("${post_url}")
13                   .formParam("username", "你的用户名")
14                   .formParam("password", “你的密码").check(currentLocation.is("http://localhost:8080/")))
15               .pause(10 seconds)
16   setUp(scn.inject(atOnceUsers(2)).protocols(httpConf))
17 }

 

mueas工程修改好了,通过git将新修改提交到远程仓库,方便jenkins管理。

到此,可以配置jenkins了,创建一个新的Job,配置基本信息可以参考前面Jenkins的基础篇,这里,主要是强调一下,关于这个gatling集成应用的配置。主要在build部分。下面这个图,主要是Pre Steps里面的Execute shell的编写,用来清除环境,主要是杀掉可能存在的应用。脚本很简单,自己看看就明白。

再就是Post Steps的配置,完成两步工作,第一步是启动mueas应用,第二步,就是启用gatling来进行压力测试。

 

到这里,所有的配置,关于gatling在jenkins的集成,全部完成。现在可以启动jenkins的job了。直接Build。完成后,可以看到下面的日志信息。

  1 Started by user anonymous
  2 Building in workspace /root/.jenkins/jobs/mueas-gatling/workspace
  3  > git rev-parse --is-inside-work-tree # timeout=10
  4 Fetching changes from the remote Git repository
  5  > git config remote.origin.url git@109.105.5.108:/data/git/mueas.git # timeout=10
  6 Fetching upstream changes from git@109.105.5.108:/data/git/mueas.git
  7  > git --version # timeout=10
  8 using GIT_SSH to set credentials root private key
  9  > git -c core.askpass=true fetch --tags --progress git@109.105.5.108:/data/git/mueas.git +refs/heads/*:refs/remotes/origin/*
 10  > git rev-parse refs/remotes/origin/master^{commit} # timeout=10
 11  > git rev-parse refs/remotes/origin/origin/master^{commit} # timeout=10
 12 Checking out Revision b9dc8261faf8d172c9ee689048b232b9b7c698d2 (refs/remotes/origin/master)
 13  > git config core.sparsecheckout # timeout=10
 14  > git checkout -f b9dc8261faf8d172c9ee689048b232b9b7c698d2
 15  > git rev-list 7ae96f26da0f7b1ff289b6008d3531872938bd17 # timeout=10
 16  > git tag -a -f -m Jenkins Build #15 jenkins-mueas-gatling-15 # timeout=10
 17 [workspace] $ /bin/bash /tmp/hudson7254261757720827244.sh
 18 ================= PRE STEPS TRACKING BEGIN =================
 19 WORKSPACE: /root/.jenkins/jobs/mueas-gatling/workspace
 20 target dir: /root/.jenkins/jobs/mueas-gatling/workspace/target
 21 war file: /root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT.war
 22 specified running instance: mueas-0.0.1-SNAPSHOT.war --server.port=8080
 23 runningpid: 
 24 There is no running instance as specified
 25 ================= PRE STEPS TRACKING END ===================
 26 Parsing POMs
 27 [workspace] $ /usr/java/jdk1.8.0_65/bin/java -cp /root/.jenkins/plugins/maven-plugin/WEB-INF/lib/maven31-agent-1.5.jar:/usr/local/apache-maven-3.3.3/boot/plexus-classworlds-2.5.2.jar:/usr/local/apache-maven-3.3.3/conf/logging jenkins.maven3.agent.Maven31Main /usr/local/apache-maven-3.3.3 /root/.jenkins/war/WEB-INF/lib/remoting-2.53.2.jar /root/.jenkins/plugins/maven-plugin/WEB-INF/lib/maven31-interceptor-1.5.jar /root/.jenkins/plugins/maven-plugin/WEB-INF/lib/maven3-interceptor-commons-1.5.jar 48577
 28 <===[JENKINS REMOTING CAPACITY]===>???channel started
 29 Executing Maven:  -B -f /root/.jenkins/jobs/mueas-gatling/workspace/pom.xml -s /root/.m2/settings.xml -gs /usr/local/apache-maven-3.3.3/conf/settings.xml package -Dmaven.test.skip=true
 30 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - Scanning for projects...
 31 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger -                                                                         
 32 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
 33 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - Building mueas 0.0.1-SNAPSHOT
 34 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
 35 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 36 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- maven-resources-plugin:2.6:resources (default-resources) @ mueas ---
 37 [pool-1-thread-1 for channel] INFO org.apache.maven.shared.filtering.DefaultMavenResourcesFiltering - Using 'UTF-8' encoding to copy filtered resources.
 38 [pool-1-thread-1 for channel] INFO org.apache.maven.shared.filtering.DefaultMavenResourcesFiltering - Copying 0 resource
 39 [pool-1-thread-1 for channel] INFO org.apache.maven.shared.filtering.DefaultMavenResourcesFiltering - Copying 863 resources
 40 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 41 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- maven-compiler-plugin:3.1:compile (default-compile) @ mueas ---
 42 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.compiler.CompilerMojo - Nothing to compile - all classes are up to date
 43 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 44 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- maven-resources-plugin:2.6:testResources (default-testResources) @ mueas ---
 45 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.resources.TestResourcesMojo - Not copying test resources
 46 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 47 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- maven-compiler-plugin:3.1:testCompile (default-testCompile) @ mueas ---
 48 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.compiler.TestCompilerMojo - Not compiling test sources
 49 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 50 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- maven-surefire-plugin:2.17:test (default-test) @ mueas ---
 51 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.surefire.SurefirePlugin - Tests are skipped.
 52 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 53 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- maven-war-plugin:2.5:war (default-war) @ mueas ---
 54 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.war.WarMojo - Packaging webapp
 55 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.war.WarMojo - Assembling webapp [mueas] in [/root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT]
 56 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.war.WarMojo - Processing war project
 57 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.war.WarMojo - Copying webapp resources [/root/.jenkins/jobs/mueas-gatling/workspace/src/main/webapp]
 58 [pool-1-thread-1 for channel] INFO org.apache.maven.plugin.war.WarMojo - Webapp assembled in [470 msecs]
 59 [pool-1-thread-1 for channel] INFO org.codehaus.plexus.archiver.war.WarArchiver - Building war: /root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT.war
 60 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - 
 61 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - --- spring-boot-maven-plugin:1.2.7.RELEASE:repackage (default) @ mueas ---
 62 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
 63 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - BUILD SUCCESS
 64 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
 65 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - Total time: 11.598 s
 66 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - Finished at: 2016-01-22T11:51:28+08:00
 67 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - Final Memory: 34M/381M
 68 [pool-1-thread-1 for channel] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
 69 Waiting for Jenkins to finish collecting data
 70 [JENKINS] Archiving /root/.jenkins/jobs/mueas-gatling/workspace/pom.xml to com.tinguish/mueas/0.0.1-SNAPSHOT/mueas-0.0.1-SNAPSHOT.pom
 71 [JENKINS] Archiving /root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT.war to com.tinguish/mueas/0.0.1-SNAPSHOT/mueas-0.0.1-SNAPSHOT.war
 72 channel stopped
 73 [workspace] $ /bin/bash /tmp/hudson1088999714714478379.sh
 74 ================= POST STEPS TRACKING BEGIN =================
 75 WORKSPACE: /root/.jenkins/jobs/mueas-gatling/workspace
 76 target dir: /root/.jenkins/jobs/mueas-gatling/workspace/target
 77 war file: /root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT.war
 78 BEGIN TO DO GATLING SIMULATION....
 79 SLF4J: Class path contains multiple SLF4J bindings.
 80 SLF4J: Found binding in [jar:file:/root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT.war!/WEB-INF/lib/logback-classic-1.1.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
 81 SLF4J: Found binding in [jar:file:/root/.jenkins/jobs/mueas-gatling/workspace/target/mueas-0.0.1-SNAPSHOT.war!/WEB-INF/lib/slf4j-log4j12-1.7.12.jar!/org/slf4j/impl/StaticLoggerBinder.class]
 82 SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
 83 SLF4J: Actual binding is of type [ch.qos.logback.classic.util.ContextSelectorStaticBinder]
 84 
 85   .   ____          _            __ _ _
 86  /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
 87 ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 88  \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
 89   '  |____| .__|_| |_|_| |_\__, | / / / /
 90  =========|_|==============|___/=/_/_/_/
 91  :: Spring Boot ::        (v1.2.7.RELEASE)
 92 
 93 2016-01-22 11:51:31.766  INFO 6660 --- [           main] com.tinguish.mueas.Application           : Starting Application on CloudGame with PID 6660 
 94 
 95 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
 96 这里省略了mueas项目启动的日志,和这个博文的重点不相干,且涉及到项目机密
 97 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
 98 
 99 2016-01-22 11:51:55.192  INFO 6660 --- [           main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http)
100 2016-01-22 11:51:55.194  INFO 6660 --- [           main] com.tinguish.mueas.Application           : Started Application in 24.398 seconds (JVM running for 25.896)
101 Simulation simple.MueasSimulation started...
102 [2016-01-22 11:52:00.499] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-2] --- HttpProtocol:123: Start warm up
103 [2016-01-22 11:52:06.012] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-2] --- HttpProtocol:169: Warm up done
104 [2016-01-22 11:52:06.030] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-2] --- Controller:91: Total number of users : 2
105 [2016-01-22 11:52:06.042] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- FileDataWriter:90: Initializing
106 [2016-01-22 11:52:06.042] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- ConsoleDataWriter:90: Initializing
107 [2016-01-22 11:52:06.052] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- ConsoleDataWriter:92: Initialized
108 [2016-01-22 11:52:06.065] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- FileDataWriter:92: Initialized
109 [2016-01-22 11:52:06.094] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-2] --- Controller:216: Start user #1295396986639070879-0
110 [2016-01-22 11:52:06.100] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-2] --- Controller:216: Start user #1295396986639070879-1
111 [2016-01-22 11:52:06.143] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- HttpEngine:270: Sending request=Redirect Login uri=http://localhost:8080/: scenario=Search mueas home page, userId=1295396986639070879-0
112 [2016-01-22 11:52:06.180] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- HttpEngine:270: Sending request=Redirect Login uri=http://localhost:8080/: scenario=Search mueas home page, userId=1295396986639070879-1
113 
114 ================================================================================
115 2016-01-22 11:52:06                                           0s elapsed
116 ---- Search mueas home page ----------------------------------------------------
117 [                                                                          ]  0%
118           waiting: 2      / active: 0      / done:0     
119 ---- Requests ------------------------------------------------------------------
120 > Global                                                   (OK=0      KO=0     )
121 
122 ================================================================================
123 
124 2016-01-22 11:52:06.291  INFO 6660 --- [nio-8080-exec-2] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring FrameworkServlet 'dispatcherServlet'
125 2016-01-22 11:52:06.291  INFO 6660 --- [nio-8080-exec-2] o.s.web.servlet.DispatcherServlet        : FrameworkServlet 'dispatcherServlet': initialization started
126 2016-01-22 11:52:06.332  INFO 6660 --- [nio-8080-exec-2] o.s.web.servlet.DispatcherServlet        : FrameworkServlet 'dispatcherServlet': initialization completed in 41 ms
127 [2016-01-22 11:52:06.450] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- HttpEngine:270: Sending request=Redirect Login uri=http://localhost:8080/login: scenario=Search mueas home page, userId=1295396986639070879-0
128 [2016-01-22 11:52:06.451] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- HttpEngine:270: Sending request=Redirect Login uri=http://localhost:8080/login: scenario=Search mueas home page, userId=1295396986639070879-1
129 [2016-01-22 11:52:07.057] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- Pause:46: Pausing for 10000ms (real=9970ms)
130 [2016-01-22 11:52:07.059] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- Pause:46: Pausing for 10000ms (real=9955ms)
131 
132 ================================================================================
133 2016-01-22 11:52:11                                           5s elapsed
134 ---- Search mueas home page ----------------------------------------------------
135 [--------------------------------------------------------------------------]  0%
136           waiting: 0      / active: 2      / done:0     
137 ---- Requests ------------------------------------------------------------------
138 > Global                                                   (OK=4      KO=0     )
139 > Redirect Login                                           (OK=2      KO=0     )
140 > Redirect Login Redirect 1                                (OK=2      KO=0     )
141 ================================================================================
142 
143 
144 ================================================================================
145 2016-01-22 11:52:16                                          10s elapsed
146 ---- Search mueas home page ----------------------------------------------------
147 [--------------------------------------------------------------------------]  0%
148           waiting: 0      / active: 2      / done:0     
149 ---- Requests ------------------------------------------------------------------
150 > Global                                                   (OK=4      KO=0     )
151 > Redirect Login                                           (OK=2      KO=0     )
152 > Redirect Login Redirect 1                                (OK=2      KO=0     )
153 ================================================================================
154 
155 [2016-01-22 11:52:17.035] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- HttpEngine:270: Sending request=Try login uri=http://localhost:8080/login: scenario=Search mueas home page, userId=1295396986639070879-1
156 [2016-01-22 11:52:17.059] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- HttpEngine:270: Sending request=Try login uri=http://localhost:8080/login: scenario=Search mueas home page, userId=1295396986639070879-0
157 [2016-01-22 11:52:17.198] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- HttpEngine:270: Sending request=Try login uri=http://localhost:8080/login: scenario=Search mueas home page, userId=1295396986639070879-1
158 [2016-01-22 11:52:17.210] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-3] --- HttpEngine:270: Sending request=Try login uri=http://localhost:8080/login: scenario=Search mueas home page, userId=1295396986639070879-0
159 [2016-01-22 11:52:17.269] log4j - ????  WARN [GatlingSystem-akka.actor.default-dispatcher-3] --- AsyncHandlerActor:119: Request 'Try login Redirect 1' failed: currentLocation.find.is(http://localhost:8080/), but actually found http://localhost:8080/login
160 [2016-01-22 11:52:17.271] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-7] --- Pause:46: Pausing for 10000ms (real=9980ms)
161 [2016-01-22 11:52:17.273] log4j - ????  WARN [GatlingSystem-akka.actor.default-dispatcher-2] --- AsyncHandlerActor:119: Request 'Try login Redirect 1' failed: currentLocation.find.is(http://localhost:8080/), but actually found http://localhost:8080/login
162 [2016-01-22 11:52:17.274] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-2] --- Pause:46: Pausing for 10000ms (real=9968ms)
163 
164 ================================================================================
165 2016-01-22 11:52:21                                          15s elapsed
166 ---- Search mueas home page ----------------------------------------------------
167 [--------------------------------------------------------------------------]  0%
168           waiting: 0      / active: 2      / done:0     
169 ---- Requests ------------------------------------------------------------------
170 > Global                                                   (OK=6      KO=2     )
171 > Redirect Login                                           (OK=2      KO=0     )
172 > Redirect Login Redirect 1                                (OK=2      KO=0     )
173 > Try login                                                (OK=2      KO=0     )
174 > Try login Redirect 1                                     (OK=0      KO=2     )
175 ---- Errors --------------------------------------------------------------------
176 > currentLocation.find.is(http://localhost:8080/), but actually       2 (100.0%)
177 found http://localhost:8080/login
178 ================================================================================
179 
180 
181 ================================================================================
182 2016-01-22 11:52:26                                          20s elapsed
183 ---- Search mueas home page ----------------------------------------------------
184 [--------------------------------------------------------------------------]  0%
185           waiting: 0      / active: 2      / done:0     
186 ---- Requests ------------------------------------------------------------------
187 > Global                                                   (OK=6      KO=2     )
188 > Redirect Login                                           (OK=2      KO=0     )
189 > Redirect Login Redirect 1                                (OK=2      KO=0     )
190 > Try login                                                (OK=2      KO=0     )
191 > Try login Redirect 1                                     (OK=0      KO=2     )
192 ---- Errors --------------------------------------------------------------------
193 > currentLocation.find.is(http://localhost:8080/), but actually       2 (100.0%)
194 found http://localhost:8080/login
195 ================================================================================
196 
197 [2016-01-22 11:52:27.263] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- Controller:203: End user #1295396986639070879-0
198 [2016-01-22 11:52:27.265] log4j - ????  INFO [GatlingSystem-akka.actor.default-dispatcher-9] --- Controller:203: End user #1295396986639070879-1
199 
200 ================================================================================
201 2016-01-22 11:52:27                                          21s elapsed
202 ---- Search mueas home page ----------------------------------------------------
203 [##########################################################################]100%
204           waiting: 0      / active: 0      / done:2     
205 ---- Requests ------------------------------------------------------------------
206 > Global                                                   (OK=6      KO=2     )
207 > Redirect Login                                           (OK=2      KO=0     )
208 > Redirect Login Redirect 1                                (OK=2      KO=0     )
209 > Try login                                                (OK=2      KO=0     )
210 > Try login Redirect 1                                     (OK=0      KO=2     )
211 ---- Errors --------------------------------------------------------------------
212 > currentLocation.find.is(http://localhost:8080/), but actually       2 (100.0%)
213 found http://localhost:8080/login
214 ================================================================================
215 
216 Simulation finished
217 Parsing log file(s)...
218 [2016-01-22 11:52:27.503] log4j - ????  INFO [main] --- FileDataReader:56: Collected List(/root/.jenkins/jobs/mueas-gatling/workspace/target/gatling/results/mueassimulation-1453434726032/simulation.log) from mueassimulation-1453434726032
219 [2016-01-22 11:52:27.509] log4j - ????  INFO [main] --- FileDataReader:73: First pass
220 [2016-01-22 11:52:27.514] log4j - ????  INFO [main] --- FileDataReader:118: First pass done: read 13 lines
221 [2016-01-22 11:52:27.517] log4j - ????  INFO [main] --- FileDataReader:132: Second pass
222 [2016-01-22 11:52:27.544] log4j - ????  INFO [main] --- FileDataReader:157: Second pass: read 13 lines
223 Parsing log file(s) done
224 Generating reports...
225 
226 ================================================================================
227 ---- Global Information --------------------------------------------------------
228 > request count                                          8 (OK=6      KO=2     )
229 > min response time                                     62 (OK=148    KO=62    )
230 > max response time                                    573 (OK=573    KO=68    )
231 > mean response time                                   258 (OK=322    KO=65    )
232 > std deviation                                        189 (OK=176    KO=3     )
233 > response time 50th percentile                        194 (OK=250    KO=65    )
234 > response time 75th percentile                        339 (OK=485    KO=66    )
235 > mean requests/sec                                  0.378 (OK=0.283  KO=0.094 )
236 ---- Response Time Distribution ------------------------------------------------
237 > t < 800 ms                                             6 ( 75%)
238 > 800 ms < t < 1200 ms                                   0 (  0%)
239 > t > 1200 ms                                            0 (  0%)
240 > failed                                                 2 ( 25%)
241 ---- Errors --------------------------------------------------------------------
242 > currentLocation.find.is(http://localhost:8080/), but actually       2 (100.0%)
243 found http://localhost:8080/login
244 ================================================================================
245 
246 Reports generated in 0s.
247 Please open the following file: /root/.jenkins/jobs/mueas-gatling/workspace/target/gatling/results/mueassimulation-1453434726032/index.html
248 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
249 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - BUILD SUCCESS
250 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
251 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - Total time: 55.110 s
252 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - Finished at: 2016-01-22T11:52:27+08:00
253 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - Final Memory: 13M/228M
254 [main] INFO org.apache.maven.cli.event.ExecutionEventLogger - ------------------------------------------------------------------------
255 ================= POST STEPS TRACKING END ===================
256 Process leaked file descriptors. See http://wiki.jenkins-ci.org/display/JENKINS/Spawning+processes+from+build for more information
257 Archiving Gatling reports...
258 2016-01-22 11:52:38.063  INFO 6660 --- [       Thread-2] ationConfigEmbeddedWebApplicationContext : Closing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@3e795823: startup date [Fri Jan 22 11:51:32 CST 2016]; root of context hierarchy
259 2016-01-22 11:52:38.065  INFO 6660 --- [       Thread-2] o.s.c.support.DefaultLifecycleProcessor  : Stopping beans in phase 2147483647
260 Adding report 'mueassimulation-1453434726032'
261 Finished: SUCCESS
View Code

从上面的log日志中可以发现,gatling的测试结果是一个逻辑正常的测试,虽然check点失败(因为我给的用户名和密码都不对,所以登录失败,不可能进入到项目的主目录,只会停留在login的页面。),但是gatling的测试流程是没有问题的。

 

我执行了两次,没有做任何修改,因为一次测试,gatling的结果图上只有一个点,看不出差别。两次之间,有时间上的差别。。。

 

关于gatling和jenkins的集成的官方信息,可以参考一下下面的链接:

http://gatling.io/docs/2.1.7/extensions/jenkins_plugin.html

http://gatling.io/docs/2.1.7/extensions/maven_plugin.html?highlight=maven%20plugin

 

到此完