git 使用出现Permission denied (publickey). fatal: Could not read from remote repository.

本文主要讲述使用git clone带–recursive参数命令时出现权限错误的问题。原因是本地或服务器未生成ssh key,给出了解决办法,包括生成ssh key、添加到ssh-agent、复制到GitHub账号等步骤,最后验证Key解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

git clone命令为:git clone git@github.com:peiyunh/tiny.git

  而当我在ternimal下执行这条语句的时候,出现错误:

  Permissiondenied (publickey).

  fatal:Could not read from remote repository.

  Pleasemake sure you have the correct access rights

  and the repository exists.

  但是其实执行命令:git clone git@github.com:peiyunh/tiny.git 是没有问题的(不加–recursive参数),于是百度了一番,我理解的是原因是由于你在本地(或者服务器上)没有生成ssh key,你可以在ternimal下执行:

  cd ~/.ssh ls来查看是否有文件id_rsa以及文件id_rsa.pub,如下图所示:(我的已经生成了,所以我ls后会显示。)
  这里写图片描述
下面记录下解决办法:

  1.首先,如果你没有ssh key的话,在ternimal下输入命令:ssh-keygen -t rsa -C “youremail@example.com”, youremail@example.com改为自己的邮箱即可,途中会让你输入密码啥的,不需要管,一路回车即可,会生成你的ssh key。(如果重新生成的话会覆盖之前的ssh key。)
  这里写图片描述

 2.然后再ternimal下执行命令:

  ssh -v git@github.com

  最后两句会出现:

  No more authentication methods to try.

  Permission denied (publickey).

  3.这时候再在ternimal下输入:

  ssh-agent -s

  然后会提示类似的信息:

  SSH_AUTH_SOCK=/tmp/ssh-GTpABX1a05qH/agent.404; export SSH_AUTH_SOCK;

  SSH_AGENT_PID=13144; export SSH_AGENT_PID;

  echo Agent pid 13144;

  4.接着再输入:

  ssh-add ~/.ssh/id_rsa

  这时候应该会提示:

  Identity added: …(这里是一些ssh key文件路径的信息)

  (注意)如果出现错误提示:

  Could not open a connection to your authentication agent.

  请执行命令:eval ssh-agent -s后继续执行命令 ssh-add ~/.ssh/id_rsa,这时候一般没问题啦。

  5.打开你刚刚生成的id_rsa.pub,将里面的内容复制,进入你的github账号,在settings下,SSH and GPG keys下new SSH key,title随便取一个名字,然后将id_rsa.pub里的内容复制到Key中,完成后Add SSH Key。

  6.最后一步,验证Key

  在ternimal下输入命令:

  ssh -T git@github.com

  提示:Hi xxx! You’ve successfully authenticated, but GitHub does not provide shell access.

  这时候你的问题就解决啦,可以使用命令 git clone –recursive git@github.com:peiyunh/tiny.git 去下载你的代码啦。

### Git 权限被拒绝问题的解决方案 当遇到 `Permission denied (publickey)` 和 `fatal: Could not read from remote repository` 错误时,通常是因为 SSH 密钥配置不正确或未正确设置远程仓库的身份验证。以下是详细的解决方法: #### 1. 检查并生成 SSH 密钥 如果尚未生成 SSH 密钥,则需要通过以下命令创建密钥对: ```bash ssh-keygen -t rsa -b 4096 -C "your_email@example.com" ``` 此操作会提示输入保存位置和密码短语(可选)。默认情况下,SSH 密钥存储在 `~/.ssh/id_rsa.pub` 中[^3]。 #### 2. 将公钥添加到目标平台 将生成的公钥内容复制到剪贴板: ```bash cat ~/.ssh/id_rsa.pub ``` 然后登录到对应的代码托管平台(如 GitHub、GitLab 或 Gitee),找到账户设置中的 **SSH Keys** 部分,并粘贴该公钥[^3]。 #### 3. 测试 SSH 连接 测试与远程服务器的连接是否成功: ```bash ssh -T git@<remote-server> ``` 例如,对于 Gitee 平台可以运行: ```bash ssh -T git@gitee.com ``` 如果一切正常,应返回一条消息表明身份已确认;否则需重新检查密钥配置。 #### 4. 修改本地 `.ssh/config` 文件 有时可能涉及多个不同的主机名或者端口调整,在这种情况下编辑用户的 SSH 配置文件非常重要。打开或新建 `~/.ssh/config` 文件,加入如下条目: ```plaintext Host gitee.com HostName gitee.com User git IdentityFile ~/.ssh/id_rsa ``` 上述例子针对的是 Gitee 的情况,请根据实际使用的站点修改相应字段[^2]。 #### 5. 清理旧缓存数据 某些时候即使完成了前面所有的步骤仍然无法解决问题,这可能是由于系统保留了错误的历史记录所致。尝试清除这些残留信息后再重试一次完整的流程即可消除干扰因素[^1]。 综上所述,按照以上五个方面逐一排查能够有效处理大部分因缺少适当授权而导致的操作失败现象。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值