基于docker容器使用Jacoco实现webapp测试覆盖率监控

  1. 自行下载jacoco最新版本,主要用到两个jar包:jacocoagent.jar,jacococli.jar
  2. 替换JVM参数,把jacoco两个jar包放在tomcat/bin目录,执行定时器设置脚本
    auto.sh脚本内容:
#!/bin/sh
sed -i 's/server/server -javaagent:jacocoagent.jar=includes=com.*,output=tcpserver,port=6300,address=127.0.0.1 ,append=false/g' /usr/local/tomcat/bin/setenv.sh
cd /usr/local/tomcat/bin && rm -rf jacoco*.jar && wget 192.168.195.93:9999/jacocoagent.jar && wget 192.168.195.93:9999/jacococli.jar
cd /usr/local/tomcat/bin && rm -rf auto_dump.sh && wget 192.168.195.93:9999/auto_dump.sh && chmod +x auto_dump.sh
echo '*/10     *       *       *       *       /usr/local/tomcat/bin/auto_dump.sh' >> /etc/crontabs/root
crond restart
  1. 每隔10分钟定时导出覆盖率报告
    auto_dump.sh脚本内容:
#!/bin/sh
cd /usr/local/tomcat/webapps
fn=`basename *.war`
name="${fn%%.*}"
mkdir -p /usr/local/tomcat/webapps/jacoco
java -jar /usr/local/tomcat/bin/jacococli.jar dump --address localhost --port 6300 --destfile /usr/local/tomcat/webapps/jacoco/jacoco.exec
echo 'dump success'
java -jar /usr/local/tomcat/bin/jacococli.jar report /usr/local/tomcat/webapps/jacoco/jacoco.exec --html /usr/local/tomcat/webapps/jacoco --classfiles /usr/local/tomcat/webapps/$name/WEB-INF/
echo 'report generate success'
  1. 每个容器都要执行以下命令:
RUN echo "cd /usr/local/tomcat/bin && rm -rf auto.sh && wget 192.168.195.93:9999/auto.sh && chmod +x auto.sh" >> /bin/startWeb && echo "/usr/local/tomcat/bin/auto.sh" >> /bin/startWeb
  1. 写一个静态jacoco.html页面,每个tomcat的端口都对应上
<html><head>		
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>测试覆盖率监控</title>
	</head>
	<body>
		<h5><font color="black">基础组:</font></h5>
		<h5><a href="http://192.168.1.111:8894/jacoco/index.html"><font color="green">xx-webapp</font></a><font color="green">
		<h5><a href="http://192.168.1.111:8888/jacoco/index.html"><font color="green">xx-webapp</font></a><font color="green">
		<h5><a href="http://192.168.1.111:8890/jacoco/index.html"><font color="green">xx-webapp</font></a><font color="green">
		<h5><a href="http://192.168.1.111:8891/jacoco/index.html"><font color="green">xx-webapp</font></a><font color
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
云平台基于Docker容器的功能设计与实现通常包括以下几个方面: 1. 资源管理:云平台需要对Docker容器进行资源管理,包括CPU、内存、存储等资源的分配和调度。可以使用容器编排工具(如Kubernetes)来实现容器的自动化部署和调度。 2. 网络管理:云平台需要提供网络功能,包括容器之间的网络通信和与外部网络的连接。可以使用容器网络模型(如Docker的overlay网络)来实现容器间的网络互通。 3. 存储管理:云平台需要提供持久化存储功能,让容器可以保存数据并在重启后恢复。可以使用容器存储卷(如Docker的volume)来实现数据的持久化。 4. 安全管理:云平台需要提供安全机制,保护容器中的应用和数据不受到恶意攻击。可以使用容器隔离技术(如Docker的namespace和cgroups)来实现容器之间的隔离。 5. 监控和日志:云平台需要提供监控和日志功能,用于实时监测容器的运行状态和收集容器的日志信息。可以使用监控工具和日志收集工具(如Prometheus和ELK)来实现监控和日志功能。 6. 弹性伸缩:云平台需要支持容器的弹性伸缩,根据负载情况自动增加或减少容器的数量。可以使用自动扩展工具(如Kubernetes的Horizontal Pod Autoscaler)来实现弹性伸缩功能。 7. 高可用性:云平台需要提供高可用性的容器服务,确保容器在节点故障时可以自动迁移或重新启动。可以使用容器编排工具和负载均衡器(如Kubernetes和Nginx)来实现高可用性。 总之,基于Docker容器的云平台功能设计与实现需要考虑资源管理、网络管理、存储管理、安全管理、监控和日志、弹性伸缩以及高可用性等方面的需求,并结合相应的技术工具来实现这些功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值