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

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

相关推荐
极客先躯24 分钟前
高级java每日一道面试题-2026年02月01日-实战篇[Docker]-Docker Volume 的生命周期管理是怎样的?
java·运维·docker·容器·持久化·架构图·容器卷
Java面试题总结41 分钟前
Linux-Ubantu-贴士-apt的地盘
linux·运维·服务器
志栋智能1 小时前
超自动化巡检:提升MTTR,缩短业务影响时间
运维·自动化
kong@react1 小时前
Rocky Linux 10.2 全面解析:企业级 CentOS 替代方案及保姆级docker安装
java·linux·运维·docker
睡不醒男孩0308232 小时前
第八篇:如何构建一站式 PostgreSQL 性能优化与智能管控平台?从盲目排查到 CLup 自动化运维演进
运维·postgresql·性能优化
某林2122 小时前
Isaac Sim 5.1.0 无头服务器部署与 RTX 显存段错误排障全记录
运维·服务器·docker·容器·isaac
m0_738120723 小时前
Docker 环境下 Vulfocus 靶场搭建全流程(附镜像源问题解决方案)
运维·服务器·网络·安全·docker·容器
二等饼干~za8986683 小时前
2026 主流 GEO 源码厂商实测:云罗 GEO、摘星智能、棋引科技技术与落地能力对比
大数据·运维·科技
Championship.23.243 小时前
Linux 3.0 音频机制深度解析:ALSA基础架构与传统音频驱动模型
linux·运维·音视频·alsa
无证驾驶梁嗖嗖3 小时前
ubuntu下测试nvme带宽和健康度
运维