这次我描述了一些稍微轻松的话题,与之前的一些帖子相比。就个人而言,我认为Grafana是一个非常酷的工具,用于可视化任何时间轴数据。事实证明,使用InfluxDB插件存储和可视化Jenkins构建结果非常容易。
1.启动码头工人集装箱
让我们从使用Grafana,InfluxDB和Jenkins开始所需的docker容器开始。
|
1
2
3
|
docker run -d --name grafana -p 3000:3000 grafana/grafanadocker run -d --name influxdb -p 8086:8086 influxdbdocker run -d --name jenkins -p 38080:8080 -p 50000:50000 jenkins |
然后,您可以运行链接到InfluxDB容器的客户端容器。使用此容器,您可以使用命令创建新数据库CREATE DATABASE grafana。
|
1
|
docker run --rm --link=influxdb -it influxdb influx -host influxdb |
2.配置Jenkins
启动Jenkins后,您需要下载一些插件。对于此示例,它应该是以下插件:
如果您对有关Jenkins配置和持续交付的更多详细信息感兴趣,请查看我之前关于该主题如何设置持续交付环境的文章。
在Manage Jenkins - > Configure System部分中添加新的InfluxDB目标。

3.在詹金斯建设管道
使用Jenkins Pipeline Plugin,我们使用Groovy语法构建管道。在第一步(1)中,我们从GitHub签出项目,然后使用Maven(2)构建它。然后我们发布JUnit和JaCoCo报告(3),最后将整个报告发送到InfluxDB(4)。
|
1
2
3
4
五
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
三十
|
node { def mvnHome try { stage('Checkout') { //(1) mvnHome = tool 'maven3' } stage('Build') { //(2) dir('service-1') { sh "'${mvnHome}/bin/mvn' -Dmaven.test.failure.ignore clean package" } } stage('Tests') { //(3) junit '**/target/surefire-reports/TEST-*.xml' archive 'target/*.jar' step([$class: 'JacocoPublisher', execPattern: '**/target/jacoco.exec']) } stage('Report') { //(4) if (currentBuild.currentResult == 'UNSTABLE') { currentBuild.result = "UNSTABLE" } else { currentBuild.result = "SUCCESS" } step([$class: 'InfluxDbPublisher', customData: null, customDataMap: null, customPrefix: null, target: 'grafana']) } } catch (Exception e) { currentBuild.result = "FAILURE" step([$class: 'InfluxDbPublisher', customData: null, customDataMap: null, customPrefix: null, target: 'grafana']) }} |
我从样本中为每个模块定义了三个管道。

4.建筑服务
添加jacoco-maven-pluginMaven插件以pom.xml启用代码覆盖率报告。
|
1
2
3
4
五
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<plugin> <groupId>org.jacoco</groupId> <artifactId>jacoco-maven-plugin</artifactId> <version>0.7.9</version> <executions> <execution> <id>default-prepare-agent</id> <goals> <goal>prepare-agent</goal> </goals> </execution> <execution> <id>default-report</id> <phase>prepare-package</phase> <goals> <goal>report</goal> </goals> </execution> </executions></plugin> |
GitHub上提供了示例应用程序源代码。它由三个简单的模块组成,它们没有做任何重要的事情,但只有构建结果可视化所需的JUnit测试。
5.配置Grafana
首先,将Grafana数据源配置为InfluxDB Docker容器实例。

使用InfluxDB插件,我们可以报告由JUnit,Cobertura,JaCoCo,Robot Framework和Performance Plugin生成的指标。在示例应用程序中,我将向您展示JUnit和JaCoCo的报告。让我们在Grafana中配置我们的图表。如下图所示,我使用管道构建时间数据定义了图形。结果按项目名称分组。

这是两张图。第一个以毫秒为单位说明每个管道构建时间数据,第二个百分比测试代码覆盖率。对于测试覆盖,我们需要从jacoco_data表中选择而不是jenkins_data,然后选择字段jacoco_method_coverage_rate。

有关使用Grafana和InfluxDB可视化指标的更多详细信息,请参阅我之前的文章使用Grafana和InfluxDB自定义指标可视化。