我正在尝试设置 Jenkins 从 bitbucket 中提取和构建一个项目。
我在 IIS 8.5 Server 2012 r2 上使用它。我已经设置了 Git 和 Bitbucket 插件。
我已经建立了一个项目如下:
Branch Specifier (blank for 'any'): "origin/master"
Run Code Online (Sandbox Code Playgroud)
我不确定这是否是问题的一部分,但我的回购中只有一个分支。
运行构建时,我收到以下错误,我找不到任何关于无效 ID 的信息,有人能指出我正确的方向吗?
看起来它正在从上次提交中获取哈希,然后说无效的 ID,我不确定这是哈希 ID 还是某种环境 ID,因为它正在引用构建目录(它确实存在并且具有正确的权限)失败时
错误日志:
Started by user Stu
Building in workspace C:\Program Files (x86)\Jenkins\workspace\Fenix
> C:\Program Files\Git\git-cmd.exe rev-parse --is-inside-work-tree # timeout=10
Fetching changes from the remote Git repository
> C:\Program Files\Git\git-cmd.exe config remote.origin.url https://user@bitbucket.org/project/project-fenix.git # timeout=10
Fetching upstream changes from https://user@bitbucket.org/project/project-fenix.git
> C:\Program Files\Git\git-cmd.exe --version # timeout=10
using GIT_ASKPASS to set credentials
> C:\Program Files\Git\git-cmd.exe fetch --tags https://user@bitbucket.org/project/project-fenix.git +refs/heads/*:refs/remotes/origin/*
> C:\Program Files\Git\git-cmd.exe rev-parse "refs/remotes/origin/master^{commit}" # timeout=10
FATAL: Invalid id: C:\Program Files (x86)\Jenkins\workspace\Fenix>
org.eclipse.jgit.errors.InvalidObjectIdException: Invalid id: C:\Program Files (x86)\Jenkins\workspace\Fenix>
at org.eclipse.jgit.lib.ObjectId.fromString(ObjectId.java:232)
at org.jenkinsci.plugins.gitclient.CliGitAPIImpl.revParse(CliGitAPIImpl.java:689)
at hudson.plugins.git.GitAPI.revParse(GitAPI.java:316)
at hudson.plugins.git.util.DefaultBuildChooser.getHeadRevision(DefaultBuildChooser.java:130)
at hudson.plugins.git.util.DefaultBuildChooser.getCandidateRevisions(DefaultBuildChooser.java:112)
at hudson.plugins.git.GitSCM.determineRevisionToBuild(GitSCM.java:992)
at hudson.plugins.git.GitSCM.checkout(GitSCM.java:1095)
at hudson.scm.SCM.checkout(SCM.java:495)
at hudson.model.AbstractProject.checkout(AbstractProject.java:1278)
at hudson.model.AbstractBuild$AbstractBuildExecution.defaultCheckout(AbstractBuild.java:604)
at jenkins.scm.SCMCheckoutStrategy.checkout(SCMCheckoutStrategy.java:86)
at hudson.model.AbstractBuild$AbstractBuildExecution.run(AbstractBuild.java:529)
at hudson.model.Run.execute(Run.java:1728)
at hudson.model.FreeStyleBuild.run(FreeStyleBuild.java:43)
at hudson.model.ResourceController.execute(ResourceController.java:98)
at hudson.model.Executor.run(Executor.java:404)
Finished: FAILURE
Run Code Online (Sandbox Code Playgroud)
我已经看到很多地方引用使用git.cmd而不是.exe,但是我的 Git 目录中不存在 cmd 文件。如果我使用任何.exe文件,它会超时并且无法建立连接,所以我正在使用C:\Program Files\Git\git-cmd.exe并且它至少正在连接。
Git 版本是 Git for Windows v2.10.2
如果有人能指出我正确的方向,我将不胜感激,因为我无法在网上找到有关此特定错误的任何信息。
请不要使用 git-cmd.exe 作为 Jenkins 的 git 实现。使用git安装的bin目录下的git.exe,或者git安装的cmd目录下的git.exe。它工作得更好,经过测试,并且是受支持的方式。
据我所知,git-cmd.exe 是与 git 捆绑在一起的程序,它用于启动包含 git 路径的 Windows 命令处理器。我印象深刻的是它可以运行任何 git 命令,但它似乎是这样做的。它不会运行所有 git 命令,而是提供新颖有趣的错误消息。
请参阅JENKINS-45212以获取该形式的 git 程序行为不正确但git.exe行为符合预期的用例示例。
| 归档时间: |
|
| 查看次数: |
2491 次 |
| 最近记录: |