浏览器工作原理(3)-TCP协议文件如何从服务器到浏览器

2024-09-07 21:18

本文主要是介绍浏览器工作原理(3)-TCP协议文件如何从服务器到浏览器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

浏览器工作原理-TCP协议,文件如何从服务器到浏览器

本周继续学习浏览器工作原理及实践,本次内容来看一下TCP协议确保文件完整的送到至浏览器

First Page 是指页面加载到首次开始绘制的时长,而影响这个性能指标的一个重要原因是网络加载速度,网络传输协议无论使用http还是websocket,都是基于TCP/IP的,所以有必要了解一下TCP/IP,对于web的性能调优和问题定位都有很大帮助。

在网络传输过程中,其实是将文件拆分为很多数据包来传输,而数据包在传输过程中有很大概率丢失或者出错,这就是常说的丢包问题。那么网络协议是如何保证页面文件能被完整的送达到浏览器呢

1 IP: 把数据包送达目的主机
数据包想要在网络中进行传输,必须要遵从网络协议(Internet Protocol),计算机的地址称为IP地址,访问网络其实是一个计算机向另一个计算机请求信息

主机A向主机B发送数据包,在传输之前,数据包上会附加上主机B的地址以确定要发送的目的地址,还会附加上主机A的地址,以便主机B做出回应,这些额外信息被封装进一个叫IP头的数据结构里,里面主要包括IP版本、源IP地址,目标IP地址,生存时间等,这部分工作是在网络层来完成的

2 UDP:把数据包送达应用程序
由于IP是非常底层的协议,只负责由主机A发送到主机B, 但是数据包到达B之后如何交给应用程序就无能为力了,这时候我们又需要高一层的协议来处理数据包,常见的是“用户数据包协议(UDP)

UDP中一个重要的信息是端口号,通过端口号,UDP就可以将数据包发给应用程序,IP通过IP地址把数据发送到指定电脑,而UDP是通过端口号把数据包分发给正确的应用程序,UDP头里面同样是封装了端口号,这一层是在传输层来完成

数据包的数据部分UDP头IP 头

一个数据包大致如上图所示

UDP的特点是:对错误包直接丢弃,发送之后无法知道是否到达,但是速度比较快

3 TCP: 把数据完成送到应用程序
由于UDP的局限性,对于安全和可靠性要求更高的传输时,就必须来使用TCP了

  • TCP采用丢包重传机制
  • TCP数据包排序功能,保证乱序的数据包能够组合成完整的文件

TCP头除了目标端口和本机端口,还包含了排序序列号

来看一下一个TCP传输生命周期

TCP传输生命周期一个传输声明周期包含建立连接,数据传输,断开连接

建立连接:这个阶段通过三次握手来完成,建立一个TCP连接时,客户端和服务器总共要发送三个数据包以确认连接的建立

数据传输:接收端需要对每个数据包进行确认,接收端接受到数据之后,要发送确认信息给发送端,如果发送端发送数据一段时间后没有收到确认信息,则认为是丢包,触发数据重传机制

断开连接:四次挥手保证双方断开连接

下一节讲HTTP协议

这篇关于浏览器工作原理(3)-TCP协议文件如何从服务器到浏览器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146188

相关文章

springboot上传zip包并解压至服务器nginx目录方式

《springboot上传zip包并解压至服务器nginx目录方式》:本文主要介绍springboot上传zip包并解压至服务器nginx目录方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录springboot上传zip包并解压至服务器nginx目录1.首先需要引入zip相关jar包2.然

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3