例如:在谷歌浏览器中输入www.baidu.com。
发送之前的准备工作
-
浏览器,首先会根据这里的域名,查询对应的IP地址 ①先查浏览器自身的缓存 ②再查hosts文件 ③再查DNS服务器 -
浏览器会构造一个HTTP请求,请求中包含了刚才的域名信息 -
浏览器调用操作系统的socket api,把这个HTTP数据交给TCP来进一步处理 TCP协议需要构造一个TCP数据报 ①在发送TCP数据报之前,还需要先进行三次握手,建立连接。 此处三次握手涉及到的SYN/ACK也是同样要经过网络层,数据链路层,物理层,依次封装,到达百度服务器在依次分用。 ②具体进行数据传输,发送方就会把这个TCP数据进一步的交给IP协议进行再一次封装。 -
网络层把TCP数据报封装成了一个IP数据报(或多个IP数据报,IP协议会自动进行分包),进一步进行封装,然后再把数据交给数据链路层。 -
数据链路层会把数据再封装成以太网数据帧,在构造帧头的时候就需要根据IP映射到mac地址,这个构造的过程依赖了ARP协议,再把这个数据交给物理层传输。 -
物理层把数据转换成电信号,继续传输。
发送的途中
- 电信号沿着网线,到达了下一个设备(路由器),路由器就会针对收到的数据进行分用,物理层把数据交给数据链路层,数据链路层把数据交给网络层,路由器拿到网络层中的IP数据报,取出其中的目的IP,查询路由表,找到下一个传输的目标,进一步的再找到下一个要传输目标的Mac地址,重新进行封装(需要注意的是把数据交给数据链路层的过程中源Mac和目的Mac发生了改变)
接受方收到数据
-
数据到达接受方(百度服务器),数据要继续进行分用。 物理层把光电信号转换成以太网数据帧,交给数据链路层, 数据链路层解析出IP数据报,交给网络层(涉及到crc校验,如果发现校验和不对,说明数据是错的,直接丢弃) IP协议再进行解析,解析出一个TCP数据报(IP报头里包含着协议类型),在解析的过程中可能还涉及到组包的过程(利用IP报头中的16位标识,3标志位,13位片偏移) 再根据TCP数据报中的端口号,找到对应的进程,把数据就放入到对应socket的接受缓冲区里。 -
应用程序调用对应的socket api,从tcp接受缓冲区中读取数据,应用程序就把这个数据按照HTTP协议来解析,获取到其中的URL。根据URL中指定的路径,知道了是要获取到 / 这个根路径。 -
百度服务器会对 / 这个路径进行配置,映射到一个具体的html文件,服务器就会读取这个文件,把这个文件的内容构造成一个HTTP响应数据,然后再调用socket api进行发送。 -
重新上面封装的过程,服务器发送的响应数据也要层层封装,最终变成一个物理层上传输的光电信号。 -
继续封装,最终变成一个物理层上传输的光电信号。 -
光电信号到达下一个路由器,路由器重复分用的过程,解析到IP这一层,然后取出其中的目的IP,查路由表,找到下一个设备在哪,重新封装数据。 -
重复上面的过程,最终到达用户的主机。 -
用户主机重复上面的分用过程,依次把数据取出来,最终交给应用程序。 -
浏览器得到了HTTP响应报文,解析这个报文,获取到其中的html内容,根据html进行渲染得到页面。
|