jenkins用户在执行scp的时候如何做免密登录

一、背景

在jenkins job中执行scp的shell命令,当然不希望每次输入密码,另外处于出于安全考虑,也不建议在scp命令中指定。

所以,我们需要对远程机器进行免密登录。

本文遇到的问题是,在jenkins机器上执行scp已做到了免密,无需输入密码;但是,在jenkins job中执行scp命令,却报错Permission denied, please try again.

二、总体架构

三、scp免密

把jenkins机器上的.ssh/id_rsa添加到远程ssh机器的文件~/.ssh/authorized_keys里。

然后在jenkins机器上执行

ssh devuser@192.168.10.5

其中,192.168.10.5是ftp的地址,ssh用户是devuser,端口默认是22。

这个过程可以说是很简单,经验证,在jenkins机器上上,执行scp命令,成功地下载了zip文件到本地。

但是,当在jenkins执行scp的时候,报错见下:

bash 复制代码
# 尝试从远程机器192.168.10.5的目录/opt/php下载xxx.zip到本地(workspace目录)
+ scp phpuser@192.168.10.5:/opt/php/xxx/xxx.zip ./xxx.zip
Permission denied, please try again.
Permission denied, please try again.
phpuser@192.168.10.5: Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password).
Build step 'Execute shell' marked build as failure
Finished: FAILURE

也就是说,ssh免密登录在jenkins用户执行的时候是失效的。

四、免密用户

在Jenkins job中,尝试执行.ssh/id_rsa文件所在的路径,比如:

bash 复制代码
scp -i /root/.ssh/id_rsa phpuser@192.168.10.5:/opt/php/xxx/xxx.zip ./xxx.zip

仍旧报同样的错误。

但是jenkins机器只有一个root用户,jenkins进程本身也是root用户起的。

正当陷入纠结时,发现jenkins工作目录下也有一个.ssh目录。

  • /var/jenkins_home/.ssh

    注意:它是一个隐藏文件夹。

再次把这个文件夹下的ssh公钥添加至远程ssh的授权文件~/.ssh/authorized_keys里。

五、jenkins job 指定ssh私钥

上一步是把jenkins工作目录下的.ssh公钥做好了免密授权。

但是,jenkins job在执行scp命令时,默认读取的是/root/.ssh/id_rsa,而非/var/jenkins_home/.ssh/id_rsa。

在scp的后面指定好ssh私钥文件所在。

bash 复制代码
scp -i /var/jenkins_home/.ssh/id_rsa phpuser@192.168.10.5:/opt/php/xxx/xxx.zip ./xxx.zip

至此,jenkins用户在执行scp命令时,免密登录就实现了。

相关推荐
古月方枘Fry8 小时前
MGRE实验
运维·服务器
华科大胡子8 小时前
AI开发者的网络卡点:Anthropic连接超时
开发语言·php
stolentime9 小时前
FreeDomain 本地开发环境快速搭建指南
运维·服务器·网络
bill328227804310 小时前
AE 的 Animation Composer 描边动效玩法 + 极简 MG 制作流程(含示例)
php·composer
bush410 小时前
嵌入式linux学习记录四
linux·运维·学习
lihao lihao11 小时前
软硬链接
linux·运维·服务器
TOWE technology11 小时前
智能安防监控系统如何做好防雷?——视频信号SPD综合应用方案解析
运维·服务器·防雷产品·信号保护·信号防雷·spd
YANQ66211 小时前
7.bundlesdf本地安装
前端·webpack·node.js
楼田莉子11 小时前
Docker学习:Docker介绍及其架构介绍
运维·后端·学习·docker·容器·架构
大明者省12 小时前
IIS 端口绑定正常访问的原理说明与常见误区澄清
运维·服务器·笔记