likes
comments
collection
share

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

作者站长头像
站长
· 阅读数 3

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

执行 git 拉取,突然报错:

> 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 平台:

C:\Windows\System32\drivers\etc\hosts

Linux 平台:

/etc/hosts

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

https://www.ipaddress.com/

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

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 指令:

git config -e

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

[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 方式,如下

[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 后台获取:

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

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

再次执行 git 拉取

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 访问方式的缺点了。