jenkins 执行 ssh 命令报错Permission denied (publickey).

解决Jenkins SSH权限拒绝
本文解决了在不同环境中迁移Jenkins任务时遇到的SSH权限拒绝问题。通过对比小A和小B服务器的Jenkins配置,发现~/.ssh/目录下的密钥差异。最终通过复制正确的密钥文件到/var/lib/jenkins/.ssh/目录下,成功解决了任务执行失败的问题。

原文地址

WHAT

jenkins执行带有ssh命令的任务,报错“Permission denied (publickey).”;

WHY

手动迁移几个jenkins任务,结果有几个任务命令中带ssh,一直报错;

HOW

现象
  • 两个不同环境的服务器小A和小B,都启动了jenkins服务,上面有一个同样的任务是“ssh登录到服务器小C上执行一个命令”;
  • 原本在小A的jenkins上的任务可以正常执行;
  • 但是小B上的任务一直报Permission denied (publickey).
  • 确认了下小A和小B的~/.ssh/id_rsa.pub都是一样的;
  • 同时在小B服务器上直接ssh root@小C "echo 'hello world'"也是ok的
  • google关键字“jenkins ssh Permission denied (publickey).”找到了这个问题中的这句话“I would suggest to use the -v argument to compare the 2 outputs:

  • 于是将原本的命令ssh root@小C "echo 'hello world'"改成ssh -v root@小C "echo 'hello world',将ssh的详细信息打印出来
  • 最后几行输出为
	debug1: Next authentication method: publickey
	debug1: Trying private key: /var/lib/jenkins/.ssh/id_rsa
	debug1: Trying private key: /var/lib/jenkins/.ssh/id_dsa
	debug1: Trying private key: /var/lib/jenkins/.ssh/id_ecdsa
	debug1: Trying private key: /var/lib/jenkins/.ssh/id_ed25519
	debug1: No more authentication methods to try.
	Permission denied (publickey).
  • 找到了最关键的目录/var/lib/jenkins/.ssh/
  • 于是进去看了一眼,发现小A的目录下安安静静的躺着三个文件“authorized_keys id_rsa id_rsa.pub”
  • 而小B的目录下空空如也
  • 于是把小B的~/.ssh/复制到/var/lib/jenkins/.ssh/
  • 果然,jenkins任务成功执行了

至此,大功告成

END

未完待续……
Started by user zzl Running as SYSTEM Building in workspace /var/lib/jenkins/workspace/ruoyi The recommended git tool is: NONE using credential b3b80ec1-c9a6-4dcc-96f6-a06af4609ae3 > git rev-parse --resolve-git-dir /var/lib/jenkins/workspace/ruoyi/.git # timeout=10 Fetching changes from the remote Git repository > git config remote.origin.url git@192.168.254.11:zzl/rouyi.git # timeout=10 Fetching upstream changes from git@192.168.254.11:zzl/rouyi.git > git --version # timeout=10 > git --version # 'git version 1.8.3.1' using GIT_SSH to set credentials Verifying host key using known hosts file > git fetch --tags --progress git@192.168.254.11:zzl/rouyi.git +refs/heads/*:refs/remotes/origin/* # timeout=10 > git rev-parse refs/remotes/origin/master^{commit} # timeout=10 Checking out Revision ce3d6ec6001acce71745489686c6d74c893e5f6e (refs/remotes/origin/master) > git config core.sparsecheckout # timeout=10 > git checkout -f ce3d6ec6001acce71745489686c6d74c893e5f6e # timeout=10 Commit message: "213" > git rev-list --no-walk ce3d6ec6001acce71745489686c6d74c893e5f6e # timeout=10 [ruoyi] $ /bin/sh -xe /tmp/jenkins9596733342913347267.sh + sudo ssh root@192.168.254.12 ./maven-deploy.sh Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). 192.168.254.13 /app create sucessful!!! Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). lost connection Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). 192.168.254.14 /app create sucessful!!! Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). lost connection Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Permission denied, please try again. Permission denied, please try again. Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password). Build step 'Execute shell' marked build as failure Finished: FAILURE
最新发布
08-24
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值