PackProtocolException:使用带有 jenkins 作业的 jgitflow-maven-plugin 时无效的广告

PackProtocolException: invalid advertisement when using the jgitflow-maven-plugin withing a jenkins job

我正在使用以下由 Atlassian 团队创建并不再维护的 jgitflow-maven-plugin。每当我尝试从 Jenkins 作业中执行 release-start 时,我都会收到以下错误:

Caused by: org.eclipse.jgit.errors.PackProtocolException: invalid advertisement of <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

插件是这样导入的:

<plugin>
    <groupId>external.atlassian.jgitflow</groupId>
    <artifactId>jgitflow-maven-plugin</artifactId>
    <version>1.0-m5.1</version>
</plugin>

在pom.xml中配置如下:

  1. 单片机配置
<scm>
    <url>https://myOwnRepo.com/test</url>
    <connection>scm:git:https://myOwnRepo.com/test.git</connection>
    <developerConnection>scm:git:https://myOwnRepo.com/test.git</developerConnection>
    <tag>HEAD</tag>
</scm>
  1. 插件配置
<configuration>
    <flowInitContext>
        <masterBranchName>master</masterBranchName>
        <developBranchName>dev</developBranchName>
        <versionTagPrefix>v</versionTagPrefix>
    </flowInitContext>

    <pushFeatures>true</pushFeatures>
    <pushHotfixes>true</pushHotfixes>

    <username>myRepoUser</username>
    <password>myRepoPassword</password>

    <allowUntracked>true</allowUntracked>
</configuration>
  1. 其他配置
<executions>
    <execution>
        <id>release</id>

        <goals>
            <goal>release-start</goal>
            <goal>release-finish</goal>
        </goals>

        <configuration>
            <scmCommentPrefix>[RELEASE]</scmCommentPrefix>
        </configuration>
    </execution>

    <execution>
        <id>feature</id>

        <goals>
            <goal>feature-start</goal>
            <goal>feature-finish</goal>
        </goals>

        <configuration>
            <allowSnapshots>true</allowSnapshots>
            <scmCommentPrefix>[FEATURE]</scmCommentPrefix>
        </configuration>

    </execution>

    <execution>
        <id>hotfix</id>

        <goals>
            <goal>hotfix-start</goal>
            <goal>hotfix-finish</goal>
        </goals>

        <configuration>
            <scmCommentPrefix>[HOTFIX]</scmCommentPrefix>
        </configuration>

    </execution>
</executions>

我还尝试更改以下依赖项的版本:

<groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId>

<groupId>com.jcraft</groupId>
<artifactId>jsch.agentproxy.sshagent</artifactId>

<groupId>com.jcraft</groupId>
<artifactId>jsch.agentproxy.jsch</artifactId>

<groupId>com.jcraft</groupId>
<artifactId>jsch.agentproxy.usocket-jna</artifactId>

该项目位于使用行参数设置的代理后面。它是根据 scm 配置使用 https 克隆的。此外,为了连接,它使用令牌而不是密码。

在我的本地机器上,一切似乎都在工作,与 Jenkins 作业的唯一区别似乎是所使用的代理。

显然,导致 jenkins 作业错误行为的问题是代理(正如预期的那样)。

Jenkins 实例 运行 在代理后面。每当 maven-jgitflow-plugin 试图到达 git 仓库时,它会收到一个 403 页面作为来自仓库的响应。

更改代理配置后错误消失,插件工作。