【计算机网络】深入理解TCP协议二(连接管理机制、WAIT_TIME、滑动窗口、流量控制、拥塞控制)

这篇具有很好参考价值的文章主要介绍了【计算机网络】深入理解TCP协议二(连接管理机制、WAIT_TIME、滑动窗口、流量控制、拥塞控制)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

网络编程,计算机网络,网络,tcp/ip,网络协议

1.连接管理机制

正常情况下,TCP需要经过三次握手建立连接+四次挥手断开链接,下面看一个图:
网络编程,计算机网络,网络,tcp/ip,网络协议

  • 服务器的状态变化:
  • [CLOSED -> LISTEN] 服务器端调用listen后进入LISTEN状态, 等待客户端连接;
  • [LISTEN -> SYN_RCVD] 一旦监听到连接请求(同步报文段), 就将该连接放入内核等待队列中, 并向客户端发送SYN确认报文.
  • [SYN_RCVD -> ESTABLISHED] 服务端一旦收到客户端的确认报文, 就进入ESTABLISHED状态, 可以进行
    读写数据了.
  • [ESTABLISHED -> CLOSE_WAIT] 当客户端主动关闭连接(调用close), 服务器会收到结束报文段, 服务器返回确认报文段并进入CLOSE_WAIT;
  • [CLOSE_WAIT -> LAST_ACK] 进入CLOSE_WAIT后说明服务器准备关闭连接(需要处理完之前的数据); 当服务器真正调用close关闭连接时, 会向客户端发送FIN, 此时服务器进入LAST_ACK状态, 等待最后一个ACK到来(这个ACK是客户端确认收到了FIN)
  • [LAST_ACK -> CLOSED] 服务器收到了对FIN的ACK, 彻底关闭连接.
  • 客户端状态变化
  • [CLOSED -> SYN_SENT] 客户端调用connect, 发送同步报文段;
  • [SYN_SENT -> ESTABLISHED] connect调用成功, 则进入ESTABLISHED状态, 开始读写数据;
  • [ESTABLISHED -> FIN_WAIT_1] 客户端主动调用close时, 向服务器发送结束报文段, 同时进入FIN_WAIT_1;
  • [FIN_WAIT_1 -> FIN_WAIT_2] 客户端收到服务器对结束报文段的确认, 则进入FIN_WAIT_2, 开始等待服务器的结束报文段;
  • [FIN_WAIT_2 -> TIME_WAIT] 客户端收到服务器发来的结束报文段, 进入TIME_WAIT, 并发出LAST_ACK;
  • [TIME_WAIT -> CLOSED] 客户端要等待一个2MSL(Max Segment Life, 报文最大生存时间)的时间, 才会进入CLOSED状态.

2.再谈WAIT_TIME状态

2.1理解WAIT_TIME状态

现在做一个测试,首先启动server,然后启动client,然后用Ctrl-C使server终止,这时马上再运行server, 结果是:
网络编程,计算机网络,网络,tcp/ip,网络协议
这是因为,虽然server的应用程序终止了,但TCP协议层的连接并没有完全断开,因此不能再次监 听同样的server端口.
我们用netstat命令查看一下:
网络编程,计算机网络,网络,tcp/ip,网络协议

TCP协议规定,主动关闭连接的一方要处于TIME_ WAIT状态,等待两个MSL(maximum segment lifetime)的时间后才能回到CLOSED状态.
我们使用Ctrl-C终止了server, 所以server是主动关闭连接的一方, 在TIME_WAIT期间仍然不能再次监听同样的server端口;
MSL在RFC1122中规定为两分钟,但是各操作系统的实现不同, 在Centos7上默认配置的值是60s;
可以通过 cat /proc/sys/net/ipv4/tcp_fin_timeout 查看msl的值;

  • 为什么TIME_WAIT的时间是2MSL?

MSL是TCP报文的最大生存时间, 因此TIME_WAIT持续存在2MSL的话
就能保证在两个传输方向上的尚未被接收或迟到的报文段都已经消失(否则服务器立刻重启, 可能会收到来自上一个进程的迟到的数据, 但是这种数据很可能是错误的);
同时也是在理论上保证最后一个报文可靠到达(假设最后一个ACK丢失, 那么服务器会再重发一个FIN. 这时虽然客户端的进程不在了, 但是TCP连接还在, 仍然可以重发LAST_ACK);

2.2解决TIME_WAIT状态引起的bind失败的方法

  • 在server的TCP连接没有完全断开之前不允许重新监听, 某些情况下可能是不合理的

服务器需要处理非常大量的客户端的连接(每个连接的生存时间可能很短, 但是每秒都有很大数量的客户端来请求).
这个时候如果由服务器端主动关闭连接(比如某些客户端不活跃, 就需要被服务器端主动清理掉), 就会产
生大量TIME_WAIT连接.由于我们的请求量很大, 就可能导致TIME_WAIT的连接数很多, 每个连接都会占用一个通信五元组(源ip,源端口, 目的ip, 目的端口, 协议). 其中服务器的ip和端口和协议是固定的. 如果新来的客户端连接的ip和端口号和TIME_WAIT占用的链接重复了, 就会出现问题.

  • setsockopt函数介绍

setsockopt 是一个用于设置套接字选项的函数,通常用于配置套接字的各种属性。它可以被用于不同类型的套接字,如 TCP 套接字和 UDP 套接字,以及其他类型的网络套接字。setsockopt 允许你在编程中控制套接字的行为和参数。

下面是 setsockopt 函数的常用参数:

套接字描述符(Socket Descriptor):指定要设置选项的套接字描述符。

  • 层级(Level):指定选项的所属协议族或协议层级,如 SOL_SOCKET 表示通用套接字选项,IPPROTO_TCP 表示 TCP 协议选项,IPPROTO_IP 表示 IP 协议选项等。
  • 选项名称(Option Name):指定要设置的选项名称,如 SO_REUSEADDR 表示重用本地地址选项,TCP_NODELAY 表示禁用 Nagle 算法选项等。
  • 选项值(Option Value):设置选项的新值,这个值的数据类型和选项名称有关,通常是一个指向某种数据类型的指针,例如 int、struct timeval 等。
  • 选项值的长度(Option Length):指定选项值的长度。
    通过 setsockopt,你可以配置诸如套接字缓冲区大小、重用地址、禁用 Nagle 算法、设置超时等多种选项,以满足你的网络通信需求。这个函数在网络编程中经常用于优化套接字的性能和行为,确保数据传输的可靠性和效率。
  • 需要注意的是,setsockopt 函数的错误处理很重要,因为配置错误的套接字选项可能导致不稳定的网络行为或错误。因此,在使用该函数时,建议检查返回值以确保选项设置成功。
  • 实际案例:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <netinet/in.h>
#include <netinet/tcp.h>

int main() {
    // 创建 TCP 套接字
    int sockfd = socket(AF_INET, SOCK_STREAM, 0);
    if (sockfd < 0) {
        perror("socket");
        exit(EXIT_FAILURE);
    }

    // 设置 TCP 连接超时时间为 5 秒
    struct timeval timeout;
    timeout.tv_sec = 5; // 5 秒
    timeout.tv_usec = 0;

    if (setsockopt(sockfd, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout)) < 0) {
        perror("setsockopt");
        close(sockfd);
        exit(EXIT_FAILURE);
    }

    // 尝试连接到远程服务器
    struct sockaddr_in server_addr;
    memset(&server_addr, 0, sizeof(server_addr));
    server_addr.sin_family = AF_INET;
    server_addr.sin_port = htons(80); // HTTP 默认端口
    inet_pton(AF_INET, "www.example.com", &(server_addr.sin_addr));

    if (connect(sockfd, (struct sockaddr*)&server_addr, sizeof(server_addr)) < 0) {
        perror("connect");
        close(sockfd);
        exit(EXIT_FAILURE);
    }

    printf("Connected to www.example.com\n");

    // 在这里可以进行后续的数据交换或操作

    // 关闭套接字
    close(sockfd);

    return 0;
}

在上面的示例中,我们创建了一个 TCP 套接字,并使用 setsockopt 设置了接收超时时间为 5 秒。然后,我们尝试连接到 www.example.com 的 HTTP 服务。如果连接在 5 秒内成功建立,将打印 “Connected to www.example.com”。否则,连接超时会导致 connect 失败,错误处理部分将处理超时情况。

2.3监听套接字listen第二个参数介绍

if(listen(listenSock,2)<0)
{
exit(3);
}

在这里的2表示什么?当服务器在处理其他请求时来不及处理新的链接请求,监听套接字所维护的最大链接数为:2+1,相当于排队
listen底层有个backlog来维护:

backlog 是 TCP 套接字选项之一,它用于指定操作系统中已完成连接队列的最大长度。在网络编程中,当服务器接受到客户端的连接请求时,操作系统会将这些请求存储在一个已完成连接队列中,等待服务器进程调用 accept 来接受这些连接。backlog 参数控制了这个队列的最大长度。

  • 下面是关于 backlog 的一些重要信息:
  • 作用:backlog 的主要作用是限制已完成连接队列的长度,以防止服务器处理不过来的连接请求。它允许服务器在高负载情况下接受连接请求,并将未处理的连接请求排队等待处理。
  • 默认值:backlog 的默认值在不同的操作系统上可能有所不同。通常,操作系统会提供一个合理的默认值,但这个值可能不足以处理高负载情况。
  • 合适的值:合适的 backlog 值取决于服务器的负载和性能要求。如果服务器期望高并发连接,应该将 backlog 设置为较大的值,以便排队更多的连接请求。但是,设置太大的值可能会占用过多的系统资源,因此需要权衡。
  • 超出 backlog 的连接请求:如果有更多的连接请求到达服务器,超过了 backlog 设置的大小,这些连接请求可能会被服务器拒绝或丢弃,具体行为取决于操作系统和服务器的配置。
  • 动态调整:一些服务器应用程序支持在运行时动态调整 backlog 值,以根据服务器的当前负载和性能要求进行优化。这可以通过重新设置套接字选项来实现。
  • 总之,backlog 是一个重要的套接字选项,用于控制服务器的连接排队行为。合适的 backlog 值应该根据服务器的性能需求和负载情况来配置,以确保服务器能够有效地处理连接请求。

这其实也是一种池化技术,进行排队等待处理,

  • 排队的意义在于:可以让服务器在有闲置的情况下,拿到链接处理相关任务,减少资源的闲置,提高利用率。
  • 为什么不能设置过长:1.太长的排队影响处理效率,新的任务需要等待很长的时间才能处理,影响客户体验;2.队列也是会占用系统资源的,设置过长占用过多的系统资源,反而可能导致服务器的效率降低!

3.滑动窗口

3.1介绍

  • 定义:滑动窗口是一个用于管理数据传输的窗口或缓冲区,通常由接收方控制。这个窗口可以看作是接收方的一个缓冲区,用于存储将要接收的数据包。发送方根据窗口的大小和接收方的状态来确定可以发送多少数据包。
  • 工作原理:滑动窗口的大小以数据包数量为单位。发送方和接收方都维护一个窗口大小的计数器。发送方将数据包发送到接收方,并等待接收方确认。一旦接收方确认收到数据包,发送方就可以向前滑动窗口,发送下一个数据包。接收方使用窗口大小来控制允许接收的数据包数量,一旦接收方处理了一个数据包,它可以向前滑动窗口以接收下一个数据包。
  • 流量控制:滑动窗口用于流量控制,以确保发送方不会发送太多数据导致接收方无法处理。接收方可以通过减小窗口大小来通知发送方减慢数据传输速度。这种机制可防止数据包的堆积和丢失。
  • 拥塞控制:滑动窗口也用于拥塞控制,帮助避免网络拥塞。当网络出现拥塞时,接收方可以减小窗口大小,通知发送方降低传输速度,从而减轻网络负载。
  • 实时调整:滑动窗口的大小通常可以动态调整,以适应网络条件的变化。这种动态调整可以根据网络延迟、丢包率等指标来执行,以确保最佳的性能。
  • 应用:滑动窗口广泛应用于TCP协议中,用于实现可靠的数据传输和流量控制。它还用于一些应用层协议,如HTTP,以管理并发连接和数据传输。
  • 没有滑动窗口情况下通信:
    网络编程,计算机网络,网络,tcp/ip,网络协议
    既然这样一发一收的方式性能较低, 那么我们一次发送多条数据, 就可以大大的提高性能(其实是将多个段的等待时间重叠在一起了).

网络编程,计算机网络,网络,tcp/ip,网络协议

窗口大小指的是无需等待确认应答而可以继续发送数据的最大值. 上图的窗口大小就是4000个字节(四个段).
发送前四个段的时候, 不需要等待任何ACK, 直接发送;
收到第一个ACK后, 滑动窗口向后移动, 继续发送第五个段的数据; 依次类推;
操作系统内核为了维护这个滑动窗口, 需要开辟 ** 发送缓冲区 ** (没有收到确认时需要重传) 来记录当前还有哪些数据没有应答;
只有确认应答过的数据, 才能从缓冲区删掉;
窗口越大, 则网络的吞吐率就越高;
网络编程,计算机网络,网络,tcp/ip,网络协议

3.2丢包情况分析

  • 情况一: 数据包已经抵达, ACK被丢了
    网络编程,计算机网络,网络,tcp/ip,网络协议
    这种情况下, 部分ACK丢了并不要紧, 因为可以通过后续的ACK进行确认,也就是说:主机A给主机B发送1~6000号数据包,主机B已经收到了,但是其中的确认请求1001(确认前1000号)和2001、3001、4001、主机A都没有收到,但是6001收到了,这就说明前6000号数据包已经成功接收!!! 如果说出现这样一种情况:1000–2000号数据包丢了,其他的数据包成功接收,那么主机B并不会确认6001号,而是确认1001,表示后面的丢失,这时候就要进行重传!

  • 情况二: 数据包就直接丢了.
    网络编程,计算机网络,网络,tcp/ip,网络协议

当某一段报文段丢失之后, 发送端会一直收到 1001 这样的ACK, 就像是在提醒发送端 "我想要的是 1001"一样;
如果发送端主机连续三次收到了同样一个 “1001” 这样的应答, 就会将对应的数据 1001 - 2000 重新发送;
这个时候接收端收到了 1001 之后, 再次返回的ACK就是7001了(因为2001 - 7000)接收端其实之前就已经收到了, 被放到了接收端操作系统内核的接收缓冲区中;

  • 这种机制被称为 “高速重发控制”(也叫 “快重传”).

4.流量控制

接收端处理数据的速度是有限的. 如果发送端发的太快, 导致接收端的缓冲区被打满, 这个时候如果发送端继续发送,就会造成丢包, 继而引起丢包重传等等一系列连锁反应.
因此TCP支持根据接收端的处理能力, 来决定发送端的发送速度. 这个机制就叫做流量控制(Flow Control);

接收端将自己可以接收的缓冲区大小放入 TCP 首部中的 “窗口大小” 字段, 通过ACK端通知发送端;
窗口大小字段越大, 说明网络的吞吐量越高;
接收端一旦发现自己的缓冲区快满了, 就会将窗口大小设置成一个更小的值通知给发送端;
发送端接受到这个窗口之后, 就会减慢自己的发送速度;
如果接收端缓冲区满了, 就会将窗口置为0; 这时发送方不再发送数据, 但是需要定期发送一个窗口探测数据段, 使接收端把窗口大小告诉发送端.

网络编程,计算机网络,网络,tcp/ip,网络协议

接收端如何把窗口大小告诉发送端呢? 回忆我们的TCP首部中, 有一个16位窗口字段, 就是存放了窗口大小信息;
那么问题来了, 16位数字最大表示65535, 那么TCP窗口最大就是65535字节么?
实际上, TCP首部40字节选项中还包含了一个窗口扩大因子M, 实际窗口大小是 窗口字段的值左移 M 位;

5.拥塞控制

5.1介绍

拥塞控制(Congestion Control)是计算机网络中的一种重要机制,用于管理网络拥塞的发生和传播,以保持网络的稳定性和性能。拥塞通常发生在网络上的某个点或链路上,当网络负载超过其容量时,数据包开始堆积、丢失或延迟增加,从而降低了网络的效率和可用性。
拥塞控制的主要目标是防止和减轻网络拥塞,确保网络吞吐量最大化,同时避免过多的数据包丢失。以下是拥塞控制的一些关键概念和技术:

  • 拥塞窗口:拥塞控制使用拥塞窗口(Congestion Window,通常缩写为cwnd)来限制发送方可以发送到网络的数据包数量。拥塞窗口的大小决定了发送方可以在网络上发送的数据包的数量。发送方会根据网络的拥塞程度来动态调整拥塞窗口的大小。
  • 拥塞信号:网络中的路由器和交换机会在发生拥塞时向发送方发送拥塞信号。这些信号可以是丢弃数据包、降低数据包优先级或发送拥塞通知等方式。发送方根据这些信号来减少发送速率。
  • 慢启动:慢启动是一种拥塞控制算法,用于在连接开始时逐渐增加发送速率,以避免立即引发网络拥塞。发送方开始时只发送少量数据包,然后根据网络的反馈逐渐增加发送速率。
  • 拥塞避免:一旦拥塞窗口达到某个阈值,发送方进入拥塞避免阶段。在这个阶段,发送方以更加保守的速率增加拥塞窗口,以避免引发拥塞。
  • 快重传和快恢复:快重传和快恢复是一种机制,用于更快地检测和响应数据包丢失。当接收方收到无序的数据包时,它可以立即向发送方发送重复确认,以触发发送方进行快速重传和快速恢复。
  • 主动队列管理:路由器和交换机可以使用主动队列管理算法来减轻拥塞。这些算法可以根据网络负载动态管理数据包的排队,以防止拥塞的发生。
  • 流量控制和窗口调整:拥塞控制和流量控制有时会被混淆,但它们有不同的目标。流量控制是为了防止接收方被发送方的数据淹没,而拥塞控制是为了防止网络拥塞。窗口大小的调整是拥塞控制的核心部分。
  • 拥塞控制在现代计算机网络中至关重要,它确保了网络的稳定性和性能。通过动态调整数据包的发送速率和响应网络拥塞,拥塞控制确保了数据的可靠传输,并提供了更好的用户体验。不同的拥塞控制算法和机制可以根据网络类型和需求进行选择和配置。

5.2慢启动

网络编程,计算机网络,网络,tcp/ip,网络协议

此处引入一个概念程为拥塞窗口
发送开始的时候, 定义拥塞窗口大小为1;
每次收到一个ACK应答, 拥塞窗口加1;
每次发送数据包的时候, 将拥塞窗口和接收端主机反馈的窗口大小做比较, 取较小的值作为实际发送的窗口

  • 像上面这样的拥塞窗口增长速度, 是指数级别的. “慢启动” 只是指初使时慢, 但是增长速度非常快.

为了不增长的那么快, 因此不能使拥塞窗口单纯的加倍.
此处引入一个叫做慢启动的阈值
当拥塞窗口超过这个阈值的时候, 不再按照指数方式增长, 而是按照线性方式增长

网络编程,计算机网络,网络,tcp/ip,网络协议
当TCP开始启动的时候, 慢启动阈值等于窗口最大值;
在每次超时重发的时候, 慢启动阈值会变成原来的一半, 同时拥塞窗口置回1;
少量的丢包, 我们仅仅是触发超时重传; 大量的丢包, 我们就认为网络拥塞;
当TCP通信开始后, 网络吞吐量会逐渐上升; 随着网络发生拥堵, 吞吐量会立刻下降;
拥塞控制, 归根结底是TCP协议想尽可能快的把数据传输给对方, 但是又要避免给网络造成太大压力的折中方案.

6.捎带应答、延时应答

相关博客: 点击跳转文章来源地址https://www.toymoban.com/news/detail-732343.html

到了这里,关于【计算机网络】深入理解TCP协议二(连接管理机制、WAIT_TIME、滑动窗口、流量控制、拥塞控制)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 05.计算机网络——TCP协议

    TCP协议——TCP全称为 “ 传输控制协议 (Transmission Control Protocol)”,对数据的传输进行一个详细的控制。 源/目的端口号: 表示数据是从哪个进程来, 到哪个进程去; 32位序号/32位确认号: 用来支持确认应答和按序到达 4位TCP报头长度: 表示该TCP报头有多少个4字节大小; 6位标志位

    2024年02月16日
    浏览(51)
  • 【计算机网络】TCP协议详解

    目录 1. TCP协议头部格式 2. TCP协议原理  2.1 可靠传输机制 2.1.1 确认应答机制 2.1.2 超时重传机制 2.1.3 连接管理机制(三次握手,四次挥手) 2.1.4 流量控制 2.1.5 拥塞控制  2.2 效率机制  2.2.1 滑动窗口  2.2.2 延迟应答  2.2.3 捎带应答  3. 粘包问题  4. TCP的异常情况  5. TCP协议特

    2024年01月18日
    浏览(50)
  • 【计算机网络篇】TCP协议

    ✅作者简介:大家好,我是小杨 📃个人主页:「小杨」的csdn博客 🐳希望大家多多支持🥰一起进步呀! TCP(Transmission Control Protocol)是一种在计算机网络中广泛使用的传输层协议,用于在网络上可靠地传输数据。 TCP 提供了可靠的、面向连接的通信,并负责数据的划分、排

    2024年02月11日
    浏览(52)
  • 【计算机网络】UDP协议与TCP协议

    端口号(Port)标识了一个主机上进行通信的不同的应用程序; 在TCP/IP协议中, 用 “源IP”, “源端口号”, “目的IP”, “目的端口号”, “协议号” 这样一个五元组来标识一个通信(可以通过netstat -n查看); 服务器的同一个服务会使用多进程或者多线程的方式,对于不同的客户端请

    2024年01月25日
    浏览(60)
  • 【计算机网络】TCP|IP协议

    目录 前言 什么是TCP/IP协议? TCP/IP协议的层次结构 TCP/IP协议的工作原理 TCP/IP协议的重要性 结语   TCP/IP协议是当今互联网世界中最重要的网络协议之一,它是网络通信的基石,为数据在网络中的传输提供了可靠性和有效性。本文将深入探讨TCP/IP协议的重要性、基本原理以及其

    2024年02月03日
    浏览(60)
  • 【计算机网络-传输层】TCP 协议

    端到端通信 :提供应用进程间的端到端通信(逻辑通信)。因此传输层又称为端到端协议。 差错检测 :对首部和数据部分进行检测。 两种协议 :面向连接的 TCP、无连接的 UDP。 复用和分用 : 概念 解释 传输层 TCP 复用 发送方的部分应用进程的报文在传输层使用 TCP 协议进

    2023年04月13日
    浏览(51)
  • 【计算机网络】UDP/TCP 协议

    端口号(Port)标识了一个主机上进行通信的不同的应用程序。在 TCP/IP 协议中, 用 “源IP”, “源端口号”, “目的IP”, “目的端口号”, “协议号” 这样一个五元组来标识一个通信(可以通过netstat -n查看)。 0 - 1023: 知名端口号,HTTP, FTP, SSH 等这些广为使用的应用层协议,它们的

    2024年03月14日
    浏览(63)
  • 【计算机网络】UDP/TCP协议

    我们先来看一张图; 在研究UDP前我们先来回答两个问题: 有效载荷如何与报头分离? 如何将有效载荷交付? 第一个问题由于在报头里面有16位UDP长度(表示的是有效载荷+报头长度),而报头长度8字节是固定的,所以分离时我们只需要用整个报文的大小减去固定的8字节报头数据即

    2024年02月08日
    浏览(66)
  • 【计算机网络】TCP协议与UDP协议详解

    文章目录 一、传输层 1、1 再次理解传输层 1、2 再次理解端口号 1、2、1 端口号范围划分 1、2、2 认识知名端口号 1、3 网络常用指令netstat 与 pidof 二、UDP协议 2、1 UDP协议的报文 2、2 UDP的特点  2、3 UDP的缓冲区 三、TCP协议 3、1 TCP协议的报文 3、2 确认应答 3、3 按序到达 3、

    2024年02月08日
    浏览(50)
  • 【计算机网络】TCP协议超详细讲解

    TCP协议广泛应用于可靠性要求较高的应用场景,如网页浏览、文件传输、电子邮件等。它提供了可靠的数据传输和流控制机制,能够确保数据的完整性和有序性。然而,由于TCP协议在传输过程中引入了较多的控制信息,因此相比于UDP协议,TCP的传输速度较慢。 TCP UDP 有连接

    2024年02月14日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包