Jenkins链接私有仓库Failed to connect to repository,stderr: No ECDSA...的问题

Jenkins版本

bash 复制代码
2.492.2

git版本

bash 复制代码
git version 2.43.5

如图,我配置好了公钥在gitee,私钥填在credential里面,但是还是会发生这种报错链接不上的情况

我采取了如下尝试:

bash 复制代码
[root@jenkins1 ~]# git ls-remote -h -- git@gitee.com:ashmcarker/ashmcracker.git HEAD

The authenticity of host 'gitee.com (182.255.33.134)' can't be established.
ECDSA key fingerprint is xxxxxxxx
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added 'gitee.com,182.255.33.134' (ECDSA) to the list of known hosts.
[root@jenkins1 ~]# ls /root/.ssh/
authorized_keys  id_rsa  id_rsa.pub  known_hosts

原因是Jenkins没有识别到gitee的ECDSA主机指纹,可以看到这里已经生成了known_hosts文件在root家目录的.ssh下,但是还是不行,

因为Jenkins默认是以自动创建的一个jenkins用户运行的,而该用户未信任gitee.com的ECDSA主机指纹,导致Host key verification failed报错。root用户执行的git ls-remote -h操作只对root用户的known_hosts有效,而Jenkins用户还是不行。

查看一下passwd目录,查看Jenkins的家目录是哪里

bash 复制代码
sudo cat /etc/passwd 

可以看到这里Jenkins的家目录为/var/lib/jenkins,并且它是个false的用户,不能登录终端

bash 复制代码
jenkins:x:991:988:Jenkins Automation Server:/var/lib/jenkins:/bin/false

这里有两种办法去解决,

解决方法一

修改Jenkins的运行用户为root,方法在下面我另一篇文章,这个时候因为我在前面已经使用git ls-remote -h -- git@gitee.com:ashmcarker/ashmcracker.git HEAD去生成了主机指纹在root的.ssh目录,所以改为root以后就可以使用私钥直接去连接gitee的私有仓库了

Jenkins 2.492.2修改运行用户为 root的方法

但是这种方法不是很推荐在生产环境进行实行,所以Jenkins 的最佳实践仍然是让它以非 root、最小权限且独立的系统用户运行

解决方法二(推荐)

由于私有仓库在 gitee.comgithub.com 等平台,SSH 连接需要验证主机指纹,且 Jenkins 用户默认往往没有任何已知主机记录。通常需要将 gitee.comgithub.com 等主机指纹加入到 Jenkins 用户的 ~/.ssh/known_hosts 文件当中,以通过 SSH 的 strict host key checking。

  1. 确认jenkins用户的家目录并创建.ssh目录:
bash 复制代码
sudo mkdir -p /var/lib/jenkins/.ssh
sudo chown -R jenkins:jenkins /var/lib/jenkins/.ssh
  1. 添加gitee主机密钥扫描结果到known_hosts
bash 复制代码
sudo -u jenkins ssh-keyscan gitee.com >> /var/lib/jenkins/.ssh/known_hosts
sudo chmod 600 /var/lib/jenkins/.ssh/known_hosts
  1. 最后测试一下是否成功:
bash 复制代码
sudo -u jenkins git ls-remote git@gitee.com:你的仓库地址.git

看到返回仓库相关信息即可。

相关推荐
Leinwin8 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
2401_865382508 小时前
信息化项目运维与运营的区别
运维·运营·信息化项目·政务信息化
漠北的哈士奇8 小时前
VMware Workstation导入ova文件时出现闪退但是没有报错信息
运维·vmware·虚拟机·闪退·ova
如意.7598 小时前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git
运维小欣8 小时前
智能体选型实战指南
运维·人工智能
yy55278 小时前
Nginx 性能优化与监控
运维·nginx·性能优化
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ9 小时前
Linux 查询某进程文件所在路径 命令
linux·运维·服务器
05大叔11 小时前
网络基础知识 域名,JSON格式,AI基础
运维·服务器·网络
安当加密11 小时前
无需改 PAM!轻量级 RADIUS + ASP身份认证系统 实现 Linux 登录双因子认证
linux·运维·服务器
dashizhi201511 小时前
服务器共享禁止保存到本地磁盘、共享文件禁止另存为本地磁盘、移动硬盘等
运维·网络·stm32·安全·电脑