写点什么

从解决 Github TimeOut 到经典面试题:从输入 URL 到浏览器显示页面发生了什么?

发布于: 2021 年 03 月 25 日

问题描述


Windows 操作系统上,push代码到git的时候,出现了Failed to connect to github.com port 443: Timed out的错误。一脸懵逼,浏览器网页也访问不了。


思路以及解决方案

一开始,我以为自己代理网络出现了问题,关掉之后,还是一样的问题。首先我们可以使用以下的命令,删除代理配置:

git config --global --unset http.proxy
复制代码


然后打开ipaddress.com,查询以下的域名,记录其 ip:

  • github.com

  • github.global.ssl.fastly.net




然后打开C:\Windows\System32\drivers\etc\hosts文件,把两个 ip 配置进去:


保存之后,打开CMD,刷新DNS,重新push

ipconfig /flushdns
复制代码


以上做法可以解决部分连接github慢的问题,主要是超时的问题,如果不是超时的问题,上面的做法是不会起作用的,这个只是把对应的域名和ip的对应关系直接映射在DNS配置上,不用去查找了,直接找到ip地址。


为什么刷新 DNS 就生效了呢?

这就涉及到一个面试经常问的一个问题了,先把问题变成:在浏览器输入一个www.baidu.com,会发生什么?间不固定。


为什么刷新DNS就生效了呢?这就涉及到一个面试经常问的一个问题了,先把问题变成:在浏览器输入一个www.baidu.com,会发生什么?


  1. 解析域名:首先需要根据域名去查找该域名的ip地址,解析前会先查看浏览器的缓存,浏览器会保存一段时间访问的网址的DNS地址,根据浏览器不同时间不固定(在chrome浏览器中输入:chrome://dns/,可以看到chrome浏览器的DNS缓存。)。


  1. 如果浏览器的缓存没有这个记录,那么就回去查找系统的缓存,系统缓存没有的情况会去查找 hosts 文件里面的 ip 地址(如果存在的话)。


  1. 如果本地的hosts文件里面没有该域名对应的ip地址,那么就会发送一个DNS请求到本地DNS服务器,一般是由网络接入服务器商提供(譬如中国移动)。


  1. 请求到达本地DNS服务器之后,也会先查询缓存,缓存有则直接返回,没有则递归查询,本地DNS服务器需要向根服务器查询。


  1. 根服务器不记录具体的域名和ip对应关系,会告诉DNS服务器,到域服务器(给出地址)上查询。


  1. 继续往域服务器查询,譬如“baidu.com”. -> .com -> baidu.com. -> www.baidu.com.,查询到之后,写入缓存并且返回 ip。


  1. 拿到ip之后,会建立TCP链接,也就是三次握手。


  1. 三次握手成功之后,浏览器发起HTTP请求,请求包括三部分:请求方法URI协议/版本,请求头,正文。


  1. 服务器处理请求,返回。


  1. 关闭TCP链接,四次握手(或称四次挥手)。


  1. 浏览器解析报文或者资源,渲染。

上述只是一个概述,具体的细节很多,这个下次具体聊聊,但是我们可以看出,在这个过程中确实涉及到了DNS的服务器以及缓存,所以我们刷新缓存之后,访问github就可以请求到对应的 ip 上去。


【刷题笔记】

Github 仓库地址:https://github.com/Damaer/codeSolution

笔记地址:https://damaer.github.io/codeSolution/


【作者简介】

秦怀,公众号【秦怀杂货店】作者,技术之路不在一时,山高水长,纵使缓慢,驰而不息。个人写作方向:Java 源码解析,JDBC,Mybatis,Spring,redis,分布式,剑指 Offer,LeetCode 等,认真写好每一篇文章,不喜欢标题党,不喜欢花里胡哨,大多写系列文章,不能保证我写的都完全正确,但是我保证所写的均经过实践或者查找资料。遗漏或者错误之处,还望指正。


2020年我写了什么?


开源刷题笔记


平日时间宝贵,只能使用晚上以及周末时间学习写作,关注我,我们一起成长吧~


发布于: 2021 年 03 月 25 日阅读数: 14
用户头像

纵使缓慢,驰而不息。 2018.05.17 加入

慢慢走,比较快。公众号:秦怀杂货店

评论

发布
暂无评论
从解决Github TimeOut到经典面试题:从输入URL到浏览器显示页面发生了什么?