什么是Jacoco?
Jacoco(java code coverage)是一个开源的Java代码覆盖率工具,Jacoco可以嵌入到Ant 、Maven中,并提供了EclEmma Eclipse插件,也可以使用JavaAgent技术监控Java程序。很多第三方的工具提供了对Jacoco的集成,如sonar、Jenkins等。

软件安装
Ant
Jacoco

Tomcat配置
1、进入你需要统计代码覆盖率的tomcat  
cd /data/tomcat-gateway/bin
2、先关闭这个tomcat的服务
正常情况下可以直接执行  ./shutdown.sh
执行结束后 ps -ef|grep tomcat名 查看是否已经正常关闭,如果还没有关闭 kill -9 pid(来源于ps的结果)
3、修改 catalina.sh  的JAVA_OPTS/CATALINA_OPTS配置
output=file时,需要shudown服务才能dump出jacoco.exec文件
declare -x CATALINA_OPTS="-javaagent:/data/jacoco/lib/jacocoagent.jar=includes=*,output=file,destfile=/data/jacocoExec/jacoco_gateway.exec"
output=tcpserver时,可以利用ant执行dump操作,无需shutdown服务;
address可以填写hostname或ip,填ip时需要注意,查看/etc/hosts的hostname映射的ip是什么
declare -x CATALINA_OPTS="-javaagent:/data/jacoco/lib/jacocoagent.jar=includes=*,output=tcpserver,port=8457,address=172.16.1.31"
具体参数的意思请查看官方文档
4、启动服务 ./startup.sh
5、查看一下JAVA_OPTS是否有修改正确,在这有个坑,有一种情况是你把JAVA_OPTS写在前面,在后面被别人的覆盖了
ps -ef|grep tomcat名 看出来的结果有没有刚才你修改的值

6、output=tcpserver时,查看tcpserver有没有启来

netstat -tunlp|grep 8457

Spring Boot服务
启动命令如下:
java -javaagent:/data/jacoco/lib/jacocoagent.jar=includes=*,output=tcpserver,port=8457,address=172.16.1.31 -jar springboot-xxx.jar

ant任务配置
配置jacocoAnt.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<project name="JaCoCo" default="run" xmlns:jacoco="antlib:org.jacoco.ant">
<!--Jacoco的安装路径-->
<property name="jacocoAntPath" value="/opt/jacoco/lib/jacocoant.jar"/>
<!--最终生成.exec文件的路径,Jacoco就是根据这个文件生成最终的报告的-->
<property name="jacocoExecPath" value="/data/jacocoExec"/>
<!--生成覆盖率报告的路径-->
<property name="jacocoReportPath" value="/data/jacocoReport"/>
<!--远程tomcat服务的ip地址 xxx.xx.xxx.163(172.16.1.31)-->
<property name="server_ip_test163" value="172.16.1.31"/>
<!--前面配置的远程tomcat服务打开的端口,要跟上面配置的一样-->
<property name="server_port_cybs" value="8456"/>
<property name="server_port_gateway" value="8457"/> <!--源代码路径-->
<property name="gatewaySrcPath" value="/data/jacocoSrc/Gateway/GATEWAY/fi-website/src/main/java"/> <property name="cybsSrcPath" value="/data/jacocoSrc/cybs/src/main/java"/> <!--.class文件路径-->
<property name="gatewayClassesPath" value="/data/jacocoClasses/gateway/WEB-INF/classes"/>
<property name="cybsClassesPath" value="/data/jacocoClasses/cybs/WEB-INF/classes"/> <!--让ant知道去哪儿找Jacoco-->
<taskdef uri="antlib:org.jacoco.ant" resource="org/jacoco/ant/antlib.xml">
<classpath path="${jacocoAntPath}"/>
</taskdef> <target name="run">
<echo message="start..."/>
<echo message="dump..."/>
<antcall target="dump"/>
<echo message="merge..."/>
<antcall target="merge"/>
<echo message="report..."/>
<antcall target="report"/>
<echo message="end..."/>
</target> <!--dump任务:
根据前面配置的ip地址,和端口号,访问目标tomcat服务,并生成.exec文件。-->
<target name="dump">
<jacoco:dump address="${server_ip_test163}" reset="true" destfile="${jacocoExecPath}/jacoco_gateway.exec" port="${server_port_gateway}" append="false"/>
<jacoco:dump address="${server_ip_test163}" reset="true" destfile="${jacocoExecPath}/jacoco_cybs.exec" port="${server_port_cybs}" append="false"/>
</target> <target name="merge">
<jacoco:merge destfile="${jacocoExecPath}/merged.exec">
<fileset dir="${jacocoExecPath}" includes="*.exec"/>
</jacoco:merge>
</target> <!--jacoco任务:
根据前面配置的源代码路径和.class文件路径,
根据dump后,生成的.exec文件,生成最终的html覆盖率报告。-->
<target name="report">
<jacoco:report>
<executiondata>
<file file="${jacocoExecPath}/merged.exec"/>
</executiondata> <structure name="JaCoCo Report">
<group name="gateway coverage">
<sourcefiles encoding="UTF-8">
<fileset dir="${gatewaySrcPath}"/>
</sourcefiles>
<classfiles>
<fileset dir="${gatewayClassesPath}"/>
</classfiles>
</group> <group name="cybs coverage">
<sourcefiles encoding="UTF-8">
<fileset dir="${cybsSrcPath}"/>
</sourcefiles>
<classfiles>
<fileset dir="${cybsClassesPath}"/>
</classfiles>
</group> </structure> <html destdir="${jacocoReportPath}" encoding="utf-8"/>
<csv destfile="${jacocoReportPath}/report.csv"/>
<xml destfile="${jacocoReportPath}/report.xml"/>
</jacoco:report>
</target>
</project>

执行ant任务
ant -f jacocoAnt.xml

<jacoco:dump address="${server_ip_test163}" reset="true" destfile="${jacocoExecPath}/jacoco_gateway.exec" port="${server_port_gateway}" append="false"/>

reset=true时,会在dump出exec文件后,清空覆盖率数据;
append=false时,dump出的exec文件会覆盖原有的exec文件;append=true时,dump出的exec文件追加至原有的exec文件;

结果展示:

+ cd /data/jacocoAntXml
+ ant -f jacocoAnt.xml
Buildfile: /data/jacocoAntXml/jacocoAnt.xml run:
[echo] start...
[echo] dump... dump:
[jacoco:dump] Connecting to /172.16.1.15:8457
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_gateway.exec
[jacoco:dump] Connecting to /172.16.1.15:8456
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_cybs.exec
[jacoco:dump] Connecting to /172.16.1.15:8470
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_creditCardBank.exec
[jacoco:dump] Connecting to /172.16.1.15:8459
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_mps.exec
[jacoco:dump] Connecting to /172.16.1.15:8451
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_accounting.exec
[jacoco:dump] Connecting to /172.16.1.15:8458
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_ordercenter.exec
[jacoco:dump] Connecting to /172.16.1.15:8453
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_notification.exec
[jacoco:dump] Connecting to /172.16.1.15:8454
[jacoco:dump] Dumping execution data to /data/jacocoExec/jacoco_poss.exec
[echo] merge... merge:
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_accounting.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_creditCardBank.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_cybs.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_gateway.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_mps.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_notification.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_ordercenter.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/jacoco_poss.exec
[jacoco:merge] Loading execution data file /data/jacocoExec/merged.exec
[jacoco:merge] Writing merged execution data to /data/jacocoExec/merged.exec
[echo] report... report:
[jacoco:report] Loading execution data file /data/jacocoExec/merged.exec
[jacoco:report] Writing bundle 'webgate coverage' with 701 classes
[jacoco:report] Writing bundle 'gateway coverage' with 198 classes [echo] end...
BUILD SUCCESSFUL

jacoco + ant远程统计(tomcat/spring boot)服务的代码覆盖率的更多相关文章

  1. Jacoco远程统计tomcat服务(Windows系统)的代码覆盖率

    Jacoco远程统计tomcat服务(Windows系统)的代码覆盖率 2017-09-21 目录 1 Jacoco的安装和设置  1.1 什么是Jacoco?  1.2 Jacoco安装  1.3 ...

  2. .net core + eureka + spring boot 服务注册与调用

    .net core + eureka + spring boot 服务注册与简单的调用 假期小长假遇上疫情只能去家里蹲了,刚好有时间总结一下. 概述 微服务架构是当前比较火的分布式架构,本篇基于.ne ...

  3. Https系列之二:https的SSL证书在服务器端的部署,基于tomcat,spring boot

    Https系列会在下面几篇文章中分别作介绍: 一:https的简单介绍及SSL证书的生成二:https的SSL证书在服务器端的部署,基于tomcat,spring boot三:让服务器同时支持http ...

  4. windows环境下,spring boot服务使用docker打包成镜像并推送到云服务器私有仓库

    最近在淘宝上学习springcloud教程,其中有几节课是讲解讲本地springboot服务打包成镜像并推送到云服务器私有仓库,但是教程里面用的事Mac环境,我的是Windows环境,而且课程里面没有 ...

  5. 【docker】docker部署spring boot服务,但是docker logs查看容器输出控制台日志,没有日志打印,日志未打印,docker logs不打印容器日志

    如题: docker部署spring boot服务,但是docker logs查看容器输出控制台日志,没有日志打印,日志未打印,docker logs不打印容器日志 场景再现: docker部署并启动 ...

  6. 【docker】centOS7上部署的mysql和spring boot服务,要求,mysql的时间、java程序服务的时间和宿主机的时间完全保持一致【修改mysql时区,临时和永久】【修改spring boot配置文件时区】【修改docker启动spring boot实例程序时区】

    要求:centOS7上部署的mysql和spring boot服务,要求,mysql的时间.java程序服务的时间和宿主机的时间完全保持一致: ============================ ...

  7. 启动/关闭Spring boot服务脚本

    启动Spring boot服务脚本 #!/bin/bash cd /test java -jar test.jar &> ./test.log & echo "成功&q ...

  8. Java框架Spring Boot & 服务治理框架Dubbo & 应用容器引擎Docker 实现微服务发布

    微服务系统架构实践 开发语言Java 8 框架使用Spring boot 服务治理框架Dubbo 容器部署Docker 持续集成Gitlab CI 持续部署Piplin 注册中心Zookeeper 服 ...

  9. 【转载收藏】使用Jacoco远程统计tomcat服务的代码覆盖率

    在做软件开发的时候经常会遇到做各种测试,这里介绍一种本人遇到的:代码覆盖率测试, 这个测试非常实用,能发现许多无效的模块和代码.强烈推荐!!!!! 网上好多资料都不全,而且没有详细的配置流程 本文将简 ...

随机推荐

  1. arduino相关文献阅读

    首推这个 https://wenku.baidu.com/view/e657b1f0bcd126fff6050baf.html 用Arduino IDE开发程序流程 当程序编写好之后,关闭前需要将文件 ...

  2. javascript实现深浅拷贝

    深浅拷贝通常是对于引用数据类型进行的(数据类型为:对象(Object).数组(Array).函数(Function)) 浅拷贝: let obj = {id: 1, name: 2}; let new ...

  3. Redis数据类型:Hashes、Geo操作指令

    Redis数据类型:Hashes.Geo操作指令 Hashes常用操作指令 Redis Hashes是一个键值对的映射表,最对能存储2^32-1(约40亿)个键值对. HSET HGET HSET:将 ...

  4. 厉害了,Apache架构师们遵循的 30 条设计原则

    作者:Srinath 翻译:贺卓凡,来源:公众号ImportSource Srinath通过不懈的努力最终总结出了30条架构原则,他主张架构师的角色应该由开发团队本身去扮演,而不是专门有个架构师团队或 ...

  5. python 重点理论知识点

    Python多线程 GIL blablabla concurrent blablabla 简单地说就是作为可能是仅有的支持多线程的解释型语言(perl的多线程是残疾,PHP没有多线程),Python的 ...

  6. CopyOnWriteArrayList详解

    可以提前读这篇文章:多读少写的场景 如何提高性能 写入时复制(CopyOnWrite)思想 写入时复制(CopyOnWrite,简称COW)思想是计算机程序设计领域中的一种优化策略.其核心思想是,如果 ...

  7. SpringBoot 集成MyBatis 中的@MapperScan注解

    SpringBoot 集成MyBatis 中的@MapperScan注解 2018年08月17日 11:41:02 文火慢炖 阅读数:398更多 个人分类: 环境搭建 在SpringBoot中集成My ...

  8. MVC 与 MVP 并无两样

    关于 MVC 的定义介绍,摘一段百度百科介绍: MVC 是一种使用 MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程序的模式: Model(模型)表示应 ...

  9. spring,get请求中带date日期格式参数,后台无法转换的问题

    今天遇到个很奇怪的问题.前端 的查询条件中带有日期范围日期的格式 是 yyyy-MM-dd HH:mm 结果后台报错 org.springframework.validation.BindExcept ...

  10. vue.js(19)--vue中子组件调用父组件的方法

    子组件是不能直接使用父组件中的方法的,需要进行事件绑定(v-on:自定义方法名="父组件方法名"),然后在子组件中再定义一个方法,使用this.$emit('自定义方法名')语句完 ...