jenkins远程登陆linux,Linux配置SSH公钥认证与Jenkins远程登录进行自动发布

本文介绍了如何通过SSH公钥认证实现Jenkins自动构建服务器与远程应用服务器之间的免密登录。主要步骤包括生成SSH密钥对,使用ssh-copy-id将公钥发送到目标服务器,并排查可能出现的登录问题。最后,配置Jenkins的SSH设置以完成自动化部署。
摘要由CSDN通过智能技术生成

公钥认证,是使用一对加密字符串,一个称为公钥(public key), 任何人都可以看到其内容,用于加密;另一个称为密钥(private key),只有拥有者才能看到,用于解密。

在使用jenkins自动构建并远程登录服务器进行发布应用的时候,需要使用SSH公钥认证来解决登录服务器的问题。

其实很简单,只需要两个指令即可。

ssh-keygen -t rsa -P ‘‘

ssh-copy-id -i ~/.ssh/id_rsa.pub

假设有两台服务器,A是Jenkins构建服务器,B是应用服务器,A构建好应用之后,将包传到B进行发布。

在A上面执行 ssh-keygen -t rsa -P ‘‘, -P后面两个单引号表示密码为空

37df9bbe7eade92c4540388b2767e899.png

之后会在~/.ssh目录下创建两个文件id_rsa(私钥),id_rsa.pub(公钥)

接下来继续在A上执行 ssh-copy-id -i ~/.ssh/id_rsa.pub ,表示将公钥发给B,发到B服务器的~/.ssh目录下

ace409e49e2176c5cb2fb6dcfceabb27.png

之后在用ssh B尝试能否免密登录B服务器,如果还是提示需要输入密码,则有以下原因

a. 非root账户可能不支持ssh公钥认证(看服务器是否有限制)

b. 传过来的公钥文件权限不够,可以给这个文件授权下  chmod 644 authorized_keys

c. 使用root账户执行ssh-copy-id -i ~/.ssh/id_rsa.pub 这个指令的时候如果需要输入密码则要配置sshd_config

vi /etc/ssh/sshd_config

e58bb86f30f9577a1d7847f7aa824de9.png

修改完后要重启sshd服务

service sshd restart

最后,如果可以SSH IP 免密登录成功说明SSH公钥认证成功。

接下来进行jenkins的SSH配置,如下

ad956e185d3a3ce53deba558e581e595.png

f49e46e5d6e38eb8b26da7a75feb00be.png

080e0d26db75a7c8a14d3b40dcffc50a.png

时间: 10-20

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值