很久不用git pull
突然发现报错如下:
ssh: connect to host github.com port 22: Connection timed out
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
于是:
ssh -T git@github.com
也发现报错也一样,说明不是公钥的问题。
开始怀疑是DNS解析错误,使用nslookup github.com
结果如下:
服务器: dns.google
Address: 8.8.8.8
非权威应答:
名称: github.com
Address: 20.205.243.166
发现能够正常解析,这就很奇怪了,能够正常解析,为什么会报22连接超时呢?,那就只能是端口问题了,但是GitHub默认端口应该是22的啊,网上有很多解决方案,说是改成443端口,我试了,ssh -T -p 443 git@github.com
发现是能成功的,说明确实存在端口访问问题,解决方案就是需要在~/.ssh
下新建一个config
文件,让以后访问GitHub以443端口访问,这里自行搜索,不再赘述。但这不是我需要的理想解决办法,因为没用从根源上解决端口22这个问题。
于是往下深究,ping 解析出来的GitHub地址,即ping 20.205.243.166
发现连接是超时。
在IPADDRESS网站查了GitHub的地址,是140.82.112.3
,完全和解析的不一样,于是又ping了下140.82.112.3
这个地址,发现居然能通,那就说的通的,默认的DNS解析是443端口能用的,要22端口能用的,在Windows下得手动指定域名解析,这里可以使用火绒的功能。
在文件最后面,加入这一行:140.82.112.3 github.com
保存即可
没装火绒的,可以在这个路径下找到hosts
文件,希望对你有帮助。
C:\Windows\System32\drivers\etc
需要注意,地址随时可能会变,如果发现有问题,可能得再次修改hosts
文件。
希望443端口访问的,可以参考反向更改hosts。