背景

centos系统升级openSSH后,服务器上无奈再拉取代码,报错如下:

起因

服务器重新安装SSH后公钥扭转,须要重新安装

ssh-keygen -t rsa -C "邮箱地址"

生成公钥,删除gitlab原有公钥,然而git pull仍然报错如下:

仍然提醒公钥有问题,没有pull权限

解决方案

1、删除.ssh/known_hosts外面的内容

2、如果从新生成公钥还是没法pull代码可能会有一下状况

3、8.8版本开始OpenSSH就不反对rsa加密算法了,mac也是因为降级了OpenSSH,所以不反对rsa算法

4、GitHub 通过在 2022 年 3 月 15 日删除旧的、不平安的密钥类型来进步安全性。

ssh-dss 自该日期起,不再反对 DSA 密钥 ( )。您不能将新的 DSA 密钥增加到您在 GitHub.com 上的个人帐户。

2021 年 11 月 2 日之前的 RSA 密钥 ( ssh-rsa ) valid_after 能够持续应用任何签名算法。在该日期之后生成的 RSA 密钥必须应用 SHA-2 签名算法。一些较旧的客户端可能须要降级能力应用 SHA-2 签名。

ssh-keygen -t ed25519 -C "<comment>"
留神:如果您应用的是不反对 Ed25519 算法的旧零碎,请应用:
ssh-keygen -t rsa -b 4096 -C "<comment>"

5、应用rsa算法生成不反对的话改用ed25519的加密形式生成公钥,配置后就能够了

以上是自己开发中遇到的问题,以及解决方案,如果帮忙请抉择应用