当我们在浏览器中输入一个网址并按下回车键时,会发生一系列复杂的过程,最终使我们能够看到网页的内容。以下是这个过程的详细步骤:
-
客户端:首先,用户在浏览器中键入网址,然后浏览器会根据这个网址生成一个HTTP请求。
-
解析URL:URL由几部分组成,包括访问数据的协议(如http或https)、Web服务器的名称(如www.baidu.com)、端口号以及目录(默认为index文件)。
-
域名解析:如果URL包含域名,浏览器就需要进行域名解析。这个过程是通过DNS服务器来完成的,DNS服务器有树形的层级关系,包括根DNS、顶级域DNS和权威DNS。浏览器会逐层向上级DNS请求,如果上级DNS的缓存中没有需要的信息,就会继续向上级请求,直到找到对应的IP地址。
-
协议栈:得到IP地址后,浏览器就可以把HTTP的传输工作交给操作系统中的协议栈。应用程序(浏览器)通过调用Socket库,来委托协议栈工作。协议栈的组成包括TCP、UDP、IP、ICMP和ARP等协议。
-
TCP:TCP协议负责在网络中传输数据。它的头部记录了源端口号和目标端口、包的序号(用于解决乱序问题)、确认号ÿ