突发:ssh 访问 Github 仓库报错:Connection reset

以下内容为本人的学习笔记,如需要转载,请声明原文链接 微信公众号「ENG八戒」mp.weixin.qq.com/s/cX2Vfl-zn...

执行 git 拉取,突然报错:

vbnet 复制代码
> git pull --tags origin main
Connection reset by 172.16.1.40 port 22
fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

更改 hosts 文件

有可能 github 网址已更新,隔一段时间可能会出现一次,通过 ping github 域名可验证此种原因

复制代码
ping github.com

如果一直无返回或者超时就可确认的确是由于 github 网址已更新,DNS 无法正确返回 github 域名的 ip。

可通过修改系统目录下的 hosts 文件解决,hosts 文件内容直接指明域名与 ip 的映射关系。一旦某些访问域名和对应 ip 被指定,就会直接跳过 DNS 的解析访问指定 ip。

Windows 10 平台:

makefile 复制代码
C:\Windows\System32\drivers\etc\hosts

Linux 平台:

bash 复制代码
/etc/hosts

通过下面的网页服务提供的搜索功能可找到最新的域名 ip:

arduino 复制代码
https://www.ipaddress.com/

比如笔者当前找到的两个域名和对应的 ip 地址:

csharp 复制代码
140.82.112.3 github.com
151.101.1.194 github.global.ssl.fastly.net

将上面的内容直接复制粘贴到 hosts 文件末尾保存即可。当然你看到本文时,域名和 ip 的映射关系可能已经发生变化,所以建议重新搜索域名对应的 ip 再采用。

改完 hosts 文件再次 ping 一下 github 域名看看,笔者顺利通过。

重新添加信任设备

另一个可能原因是后台把当前设备剔除出信任设备,可通过切换仓库访问 URL 为 HTTP 的方式,触发 github 后台重新添加可信任设备,添加时会弹窗提示,需要跟着提示操作。

Github 后台经常莫名其妙剔除我的信任设备,不知道是不是由于我经常在多个设备之间切换访问 Github 仓库。

当前工程目录下,如果是 Linux 平台,使用 git config 指令:

arduino 复制代码
git config -e

上述指令会调用默认编辑器打开当前工程 git 配置文件 .\.git\config

ini 复制代码
[core]
	repositoryformatversion = 0
	filemode = false
	bare = false
	logallrefupdates = true
	ignorecase = true
[remote "origin"]
	url = git@172.16.1.40:xxxxx/test.git
	fetch = +refs/heads/*:refs/remotes/origin/*
[branch "main"]
	remote = origin
	merge = refs/heads/main

如果是 Windows 平台建议直接用记事本打开。

config 配置文件中的 url 字段指明远程仓库的地址和访问方式,当前配置为使用 SSH 连接 git 仓库,目标是修改为使用 HTTP 方式,如下

ini 复制代码
[core]
	repositoryformatversion = 0
	filemode = false
	bare = false
	logallrefupdates = true
	ignorecase = true
[remote "origin"]
	url = http://172.16.1.40:9000/xxxxx/test.git
	fetch = +refs/heads/*:refs/remotes/origin/*
[branch "main"]
	remote = origin
	merge = refs/heads/main

SSH 和 HTTP 的访问地址都可以在 gitlab 或者 github 后台获取:

改为使用 HTTP 方式后,原有的用户目录下的 .ssh 文件夹内容将无效并且不再需要。

再次执行 git 拉取

rust 复制代码
git pull --tags origin main
info: detecting host provider for 'http://172.16.1.40:9000/'...
info: detecting host provider for 'http://172.16.1.40:9000/'...
info: detecting host provider for 'http://172.16.1.40:9000/'...
From http://172.16.1.40:9000/xxxxx/test
 * branch            main       -> FETCH_HEAD
Already up to date.

成功。

修改为 HTTP 方式后第一次访问远程 git 仓库会弹窗提示需要输入访问账户和密码,如果已经打开浏览器登录 github 后台则直接询问是否添加信任该设备,点击信任即可。视网络状况,弹窗提示可能需要等待一定时间,如果一直无反应则不妨多试几次,这个可能就是 HTTP 访问方式的缺点了。


相关推荐
鹏毓网络科技4 小时前
Cursor Rules 文件配置实战:3 个隐藏参数让我每月少写 40% 样板代码
前端·github
嘻嘻仙人20 小时前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson21 小时前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
白鲸开源1 天前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源1 天前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github
沉浸学习的匿名网友1 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
徐小夕2 天前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
深海鱼在掘金2 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
码流怪侠2 天前
【GitHub】Ponytail:给 AI 编码代理植入“懒人资深开发者“灵魂的开源插件深度拆解
程序员·github·ai编程
齐翊2 天前
怎么确认 AI 看懂了你的提示词?
人工智能·github·ai编程