作业终止后的 JaCoCo 内存分配

JaCoCo Memory Allocation after Job is terminated

上周我在与 Jenkins 合作时发现了一个奇怪的时刻。 在我的多模块项目中,我在 Jenkins 中使用 Jacoco 测试覆盖率Jacoco-plugin

我在我的 Jenkins 中开始了一些工作,当涉及到 测试阶段 时,Jacoco 进程将被创建并且在作业执行后,该进程将被关闭。但是当作业卡在测试阶段时,唯一的办法就是终止作业。但在这种情况下,Jacoco 进程 不会关闭 ,即使在 Jenkins 重新启动后也是如此。 唯一的办法就是杀死进程。

我的物理机上有一个 Jenkins 运行,另一个在 docker 中。这两种情况都会出现问题。

这是我在父 pom.xml 中的 Jacoco 配置,但我确定这不是重点。:

<plugins>
        <plugin>
            <groupId>org.jacoco</groupId>
            <artifactId>jacoco-maven-plugin</artifactId>
            <version>0.7.7.201606060606</version>
            <configuration>
                <excludes>
                    <exclude>**/*Builder.class</exclude>
                </excludes>
            </configuration>
            <executions>
                <execution>
                    <id>default-prepare-agent</id>
                    <goals>
                        <goal>prepare-agent</goal>
                    </goals>
                </execution>
                <execution>
                    <id>default-prepare-agent-integration</id>
                    <goals>
                        <goal>prepare-agent-integration</goal>
                    </goals>
                </execution>
                <execution>
                    <id>default-report</id>
                    <goals>
                        <goal>report</goal>
                    </goals>
                </execution>
                <execution>
                    <id>default-report-integration</id>
                    <goals>
                        <goal>report-integration</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>

有没有人遇到同样的问题或者有一些提示或猜测?

我还没有找到这个问题的具体解决方案,但我已经构建了一个小的解决方法。也许对某些人有用。

重点是创建一个每小时 运行 一个脚本的作业。该脚本正在检查是否有一些 jacoco 进程 运行 超过 3600 秒并杀死它们。

脚本:

#!/bin/bash

PROCESS_NAME=jacoco
MAX_TIME=3600

echo "Searching for  $PROCESS_NAME processes running for more than $MAX_TIME seconds"

pgrep -f $PROCESS_NAME | while read pid 
do
    running_time=$(ps -feo "etimes=" $pid | sed -e 's/ //g')
    if [ $running_time -gt $MAX_TIME ]
    then
        echo "killing the process with $pid"
        kill $pid
    fi       
done