git clone问题

Permission denied (publickey). fatal: Could not read from remote repository.

  博主在github上下载tiny face的的源代码的时候,遇到git clone命令为:git clone --recursive 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 去下载你的代码啦。

 

  

版权声明:

作者:王老头
出处:http://www.cnblogs.com/wmr95/p/7852832.html
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,并在文章页面明显位置给出原文链接,否则,作者将保留追究法律责任的权利。

### Git Clone 登录失败解决方案 当 `git clone` 遇到登录失败的问题时,可能的原因有多种,包括认证方式不匹配、网络代理设置错误、SSL验证问题等。以下是针对该问题的具体分析和解决办法: #### 1. 检查远程仓库地址 确认使用的 URL 是否正确。通常有两种形式的 URL: - HTTPS 地址(如 `https://github.com/username/repository.git`) - SSH 地址(如 `git@github.com:username/repository.git`) 如果当前使用的是 HTTPS 方式,而需要通过 SSH 认证,则应切换为 SSH 地址[^1]。 #### 2. 配置凭证管理器 对于 HTTPS 的克隆操作,可以配置 Git 凭证缓存工具来保存用户名和密码。运行以下命令启用凭证存储功能: ```bash git config --global credential.helper store ``` 此命令会将输入的用户名和密码永久存储在本地文件中。如果仅希望临时存储一段时间,可改为: ```bash git config --global credential.helper cache ``` #### 3. 使用个人访问令牌 (Personal Access Token, PAT) GitHub 和其他托管平台已逐步弃用传统的账户密码认证机制,推荐改用 PAT 来代替密码。具体步骤如下: - 在目标平台上创建一个新的 PAT; - 将其作为密码用于 HTTPS 克隆请求[^4]。 #### 4. 跳过 SSL 验证 在网络环境不稳定或者存在中间人攻击风险的情况下,可能会触发 SSL 错误。可以通过禁用 SSL 验证绕过这一障碍: ```bash git config --global http.sslVerify false git config --global https.sslVerify false ``` 注意:这种方法降低了安全性,在生产环境中需谨慎采用。 #### 5. 清除全局代理设置 有时由于之前设置了 HTTP 或 HTTPS 代理而导致无法正常连接至远端服务器。此时可通过下面两条指令移除这些不必要的代理参数: ```bash git config --global --unset http.proxy git config --global --unset https.proxy ``` 这一步骤有助于排除因代理引起的冲突[^5]。 #### 6. 测试浅层克隆 为了减少带宽消耗以及加快下载速度,可以选择只获取最近一次提交的历史记录数据而非整个项目历史: ```bash git clone --depth 1 https://github.com/username/repository.git ``` 这种方式特别适用于大体量仓库场景下快速取得最新版本源码的需求[^2]。 --- ### 总结 上述方法涵盖了从基础排查到高级调整的不同层面技巧,能够有效应对大多数情况下发生的 `git clone` 登陆异常状况。实际应用过程中可根据具体情况灵活选用合适的策略组合加以处理。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值