【网络小知识】TCP协议介绍/三次握手,四次挥手的作用

本文涉及的产品
数据传输服务 DTS,数据迁移 small 3个月
推荐场景:
MySQL数据库上云
数据传输服务 DTS,数据同步 small 3个月
推荐场景:
数据库上云
数据传输服务 DTS,数据同步 1个月
简介: TCP协议介绍/三次握手,四次挥手的作用

前端开发人员需要了解三次握手和四次挥手的原因是,这些概念是在客户端和服务器端之间进行网络通信时所涉及到的 TCP 协议的基本知识。而对于前端来讲,如果页面中请求服务端数据时出现连接失败、延迟等问题,就需要对TCP协议中三次握手、四次挥手所对应的状态码有一定的理解。

⭐一、TCP协议初认识

TCP(Transmission Control Protocol)是一种面向连接的传输层协议,主要用于互联网中的无差别网络。它提供了全双工、可靠、有序、面向连接和基于字节流的数据传输服务,可以确保数据以正确的方式从一个应用程序传输到另一个应用程序。

TCP 协议具体包括以下特点:

面向连接:在 TCP 传输数据之前,必须经过建立连接阶段,即三次握手。数据传输完毕后,还需要进行四次挥手来关闭连接。这个过程保证了每个数据包都能够通过可靠的方式被发现,传递到其目录地。

全双工:TCP 连接支持全双工模式,即两端可以同时发送和接收数据,而不用等待对方或交替进行发送和接收。

基于字节流:在 TCP 协议中,数据被分割成多个 IP 分组,并且不同的 IP 分组可以通过不同路径按照任意顺序到达目的地。因此,TCP 数据流被视为一个无限长的字节流,TCP 把这个流切分成若干块(segment),并负责将这些块重新组装成原始的数据。

可靠性:TCP 会利用确认、重传和超时机制等方法来确保数据的可靠性,保证每个数据包能够正确地到达它们的目标,且没有重复。

有序性:TCP 协议可以确保数据报按照发送顺序逐一传递,并在目的地重新组装回来。这就保证了接收方可以准确地重建原始消息。

流量控制和阻塞控制:TCP 协议会根据网络从源头到目的地的延迟情况和连接的带宽大小进行流量控制和拥塞控制。通过使用滑动窗口协议和其他方法,防止发送方发送过多数据,导致网络不能承受负载而发生阻塞。

综上所述,TCP 协议是一个可靠的、通用的传输协议,在互联网中广泛使用,能够在不稳定或高负荷的网络环境下实现稳定的数据传输,并通过对传输过程的状态监控、反馈机制以及流量控制等保护手段来确保数据传输的可靠性。

⭐二、三次握手四次挥手

三次握手和四次挥手是 TCP 协议中的重要概念,下面分别进行详解及其用途:

三次握手

三次握手指建立 TCP 连接时,客户端和服务端之间进行的互相确认过程。它具体包括以下步骤:

第一步(Client -> Server):客户端请求连接,发送 SYN 数据包给服务端。

第二步(Server -> Client):服务端收到 SYN 数据包后,确认收到请求,并发回 ACK 数据包,并根据自己的当前状态返回 SYN+ACK 数据包。

第三步(Client -> Server):客户端接收到服务器的 SYN+ACK 数据包后,返回 ACK 确认数据包,通知服务端连接已建立。

三次握手主要用途是确保双方能够建立可靠的 TCP 连接,验证连接正常并准备好接受和发送数据,同时防止因网络或其他原因导致连接中断或数据丢失。

四次挥手

四次挥手指关闭 TCP 连接时,客户端和服务端之间进行的互相确认过程。它具体包括以下步骤:

第一步(Client -> Server):客户端发起关闭请求,发送 FIN 数据包给服务端。

第二步(Server -> Client):服务端收到 FIN 数据包后,发送 ACK 数据包给客户端,确认已经接收到关闭请求。

第三步(Server -> Client):如果服务端还有未发送的数据,那么它将在 ACK 包中包含它的 FIN 包以通知客户端还需要等待数据传输完成。否则,服务端直接发送 FIN 数据包给客户端,标识服务端已经准备好关闭连接。

第四步(Client -> Server):客户端收到服务器的 FIN 数据包后,发回 ACK 数据包,确认接受关闭请求并通知服务端可以断开连接。

四次挥手主要用途是确保 TCP 连接能够正常地终止,防止客户端和服务端在正常关闭之前断开连接而导致数据丢失,同时释放掉资源以便其他连接使用。


相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2月前
|
负载均衡 网络协议 算法
|
26天前
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
56 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
19天前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
22天前
|
网络协议
TCP报文格式全解析:网络小白变高手的必读指南
本文深入解析TCP报文格式,涵盖源端口、目的端口、序号、确认序号、首部长度、标志字段、窗口大小、检验和、紧急指针及选项字段。每个字段的作用和意义详尽说明,帮助理解TCP协议如何确保可靠的数据传输,是互联网通信的基石。通过学习这些内容,读者可以更好地掌握TCP的工作原理及其在网络中的应用。
|
22天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
85 1
|
2月前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
79 11
|
2月前
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
73 3
|
2月前
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
133 3
|
2月前
|
网络虚拟化
生成树协议(STP)及其演进版本RSTP和MSTP,旨在解决网络中的环路问题,提高网络的可靠性和稳定性
生成树协议(STP)及其演进版本RSTP和MSTP,旨在解决网络中的环路问题,提高网络的可靠性和稳定性。本文介绍了这三种协议的原理、特点及区别,并提供了思科和华为设备的命令示例,帮助读者更好地理解和应用这些协议。
91 4
|
28天前
|
SQL 安全 网络安全
网络安全与信息安全:知识分享####
【10月更文挑战第21天】 随着数字化时代的快速发展,网络安全和信息安全已成为个人和企业不可忽视的关键问题。本文将探讨网络安全漏洞、加密技术以及安全意识的重要性,并提供一些实用的建议,帮助读者提高自身的网络安全防护能力。 ####
65 17