-
在 Jenkins 服务器上执行以下命令
生成 SSH 密钥对
ssh-keygen -t rsa -b 2048 -f ~/.ssh/id_rsa -N ""
查看公钥内容
cat ~/.ssh/id_rsa.pub
-
将显示的公钥内容复制,然后在目标服务器上执行
在目标服务器上执行
mkdir -p /root/.ssh
chmod 700 /root/.ssh
echo "这里粘贴Jenkins服务器上生成的公钥" >> /root/.ssh/authorized_keys
chmod 600 /root/.ssh/authorized_keys -
在目标服务器上检查 SSH 配置
在目标服务器上执行
cat /etc/ssh/sshd_config | grep -E "PubkeyAuthentication|PasswordAuthentication|PermitRootLogin"
如果需要修改配置
vi /etc/ssh/sshd_config
确保以下设置正确:
PubkeyAuthentication yes
PasswordAuthentication yes
PermitRootLogin yes重启SSH服务
systemctl restart sshd
-
配置完成后,在 Jenkins 服务器上测试连接
在Jenkins服务器上执行
ssh -v root@10.53.3.69
-
如果你远程属性PasswordAuthentication不小心设置成false,以下是解决方案
pipeline {
agent anyenvironment { TARGET_SERVER = 'ip' JENKINS_HOME = '/var/lib/jenkins' } stages { stage('Modify SSH Config') { steps { script { try { // 修改 SSH 配置,启用密码认证 sh ''' echo "=== 修改 SSH 配置 ===" ssh -F ${JENKINS_HOME}/.ssh/config ${TARGET_SERVER} "sudo sed -i 's/^PasswordAuthentication no/PasswordAuthentication yes/' /etc/ssh/sshd_config" echo "=== 重启 SSH 服务 ===" ssh -F ${JENKINS_HOME}/.ssh/config ${TARGET_SERVER} "sudo systemctl restart sshd" echo "=== 验证配置 ===" ssh -F ${JENKINS_HOME}/.ssh/config ${TARGET_SERVER} "cat /etc/ssh/sshd_config | grep PasswordAuthentication" ''' } catch (Exception e) { echo "Error: ${e.message}" currentBuild.result = 'FAILURE' } } } } }}
Jenkins服务器配置密钥对
TPBoreas2025-05-21 16:28
相关推荐
努力努力再努力wz14 小时前
【Linux网络系列】:JSON+HTTP,用C++手搓一个web计算器服务器!峰顶听歌的鲸鱼21 小时前
Kubernetes介绍和部署信创天地1 天前
自动化运维利器赋能信创:Ansible与SaltStack在国产系统的部署与批量管理实战东城绝神1 天前
《Linux运维总结:基于ARM64+X86_64架构使用docker-compose一键离线部署MySQL8.0.43 NDB Cluster容器版集群》creator_Li1 天前
即时通讯项目--(1)环境搭建Ka1Yan1 天前
Docker:基本概念与快速入门文静小土豆1 天前
Rocky Linux 二进制 安装K8S-1.35.0高可用集群小技工丨1 天前
华为TaiShan 200 2280 ARM服务器虚拟化部署完整指南weixin_430750931 天前
OpenMediaVault debian Linux安装配置企业私有网盘(三) 静态ip地址配置403240731 天前
[Jetson/Ubuntu 22.04] 解决挂载 exFAT 硬盘报错 “unknown filesystem type“ 及只读权限问题的终极指南