phi*_*son 7 git jenkins jenkins-pipeline
在我的jenkins管道项目中,我可以从git中检查代码...但我们需要做一些git签入,并且凭证显然不会被缓存.
stage 'Checkout'
git url: 'git@bitbucket.org:myproj.git', branch: 'master', credentialsId: '012ce21d-e920-44ee-b6f7-08df8ab41de0', variable: 'CREDENTIALS'
sh('git push') <---- fails with Permission denied (public key).
Run Code Online (Sandbox Code Playgroud)
这是样本输出:
Entering stage Checkout
Proceeding
[Pipeline] git
> git rev-parse --is-inside-work-tree # timeout=10
Fetching changes from the remote Git repository
> git config remote.origin.url git@bitbucket.org:myproj # timeout=10
Fetching upstream changes from git@bitbucket.org:myproj.git
> git --version # timeout=10
using GIT_SSH to set credentials
> git -c core.askpass=true fetch --tags --progress git@bitbucket.org:myproj.git +refs/heads/*:refs/remotes/origin/*
> git rev-parse refs/remotes/origin/master^{commit} # timeout=10
> git rev-parse refs/remotes/origin/origin/master^{commit} # timeout=10
Checking out Revision cc35402c6b39e8a1f8d55a831d2d10215d47ccd0 (refs/remotes/origin/master)
> git config core.sparsecheckout # timeout=10
> git checkout -f cc35402c6b39e8a1f8d55a831d2d10215d47ccd0 # timeout=10
> git branch -a -v --no-abbrev # timeout=10
> git branch -D master # timeout=10
> git checkout -b master cc35402c6b39e8a1f8d55a831d2d10215d47ccd0
> git rev-list cc35402c6b39e8a1f8d55a831d2d10215d47ccd0 # timeout=10
[Pipeline] sh
[myproj] Running shell script
+ git push --set-upstream origin master
Warning: Permanently added the RSA host key for IP address '192.192.143.2' to the list of known hosts.
Permission denied (publickey).
fatal: Could not read from remote repository.
Run Code Online (Sandbox Code Playgroud)
谁有一个很好的解决方案呢?
谢谢
从 Jenkins 管道示例存储库中提取,我们可以避免使用 sshagent:https : //github.com/jenkinsci/pipeline-examples/blob/master/pipeline-examples/push-git-repo/pushGitRepo.Groovy
然后对于您的示例,解决方案应该使用凭据绑定插件(https://wiki.jenkins-ci.org/display/JENKINS/Credentials+Binding+Plugin)并使用以下代码段:
stage ('Checkout') {
withCredentials([[$class: 'UsernamePasswordMultiBinding', credentialsId: '012ce21d-e920-44ee-b6f7-08df8ab41de0', usernameVariable: 'GIT_USERNAME', passwordVariable: 'GIT_PASSWORD']]) {
sh("git tag -a some_tag -m 'Jenkins'")
sh('git push git://${GIT_USERNAME}:${GIT_PASSWORD}@bitbucket.org:myproj.git')
}
}
Run Code Online (Sandbox Code Playgroud)
答案是使用 sshagent jenkins 插件:
http://getmesh.io/Blog/Jenkins+2+Pipeline+101
该插件注入 SSH_AUTH_SOCK 环境变量以供 git 访问
| 归档时间: |
|
| 查看次数: |
3845 次 |
| 最近记录: |