浏览器,输入 www.baidu,回车,到百度页面出现。中间发生了什么?

粗略的讲,进行了以下六步

  • DNS 解析:将域名解析成 IP 地址
  • TCP 连接:TCP 三次握手
  • 发送 HTTP 请求
  • 服务器处理请求并返回 HTTP 报文
  • 浏览器解析渲染页面
  • 断开连接:TCP 四次挥手

讲之前先了解一下什么是url

url

URL(Uniform Resource Locator),统一资源定位符,用于定位互联网上资源,俗称网址。

scheme://host.domain:port/path/filename

各部分解释如下:

  • scheme - 定义因特网服务的类型。常见的协议有 http、https、ftp、file,其中最常见的类型是 http,而 https 则是进行加密的网络传输。
  • host - 定义域主机(http 的默认主机是 www)
  • domain - 定义因特网域名,比如 http://baidu
  • port - 定义主机上的端口号(http 的默认端口号是 80)
  • path - 定义服务器上的路径(如果省略,则文档必须位于网站的根目录中)。
  • filename - 定义文档/资源的名称

1>域名解析(DNS)

​在浏览器输入网址后,首先要经过域名解析,因为浏览器并不能直接通过域名找到对应的服务器,而是要通过 IP 地址。DNS 协议提供通过域名查找 IP 地址,或逆向从 IP 地址反查域名的服务。DNS 是一个网络服务器,我们的域名解析简单来说就是在 DNS 上记录一条信息记录。

浏览器如何通过域名去查询 URL 对应的 IP 呢

  • 浏览器缓存 – 浏览器会缓存DNS记录一段时间。 (2分钟到30分钟不等)。

  • 系统缓存 – 如果在浏览器缓存里没有找到需要的记录,浏览器会做一个系统调用(windows里是gethostbyname)。

  • 路由器缓存 – 接着,前面的查询请求发向路由器,它一般会有自己的DNS缓存。

  • ISP DNS 缓存 – ISP 有专门的 DNS 服务器应对 DNS 查询请求。

  • 递归搜索 – 你的ISP的DNS服务器从根域名服务器开始进行递归搜索,从顶级域名服务器到baidu的域名服务器。一般DNS服务器的缓存中会有域名服务器中的域名,所以到顶级服务器的匹配过程不是那么必要了。

  • 浏览器通过向 DNS 服务器发送域名,DNS 服务器查询到与域名相对应的 IP 地址,然后返回给浏览器,浏览器再将 IP 地址打在