为什么会有TCP/IP协议?

嵌入式大杂烩 2021-06-08 22:29

点击上方「嵌入式大杂烩」,选择「置顶公众号」第一时间查看嵌入式笔记!

为什么会有TCP/IP协议

在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别。

就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样。计算机使用者意识到,计算机只是单兵作战并不会发挥太大的作用。

只有把它们联合起来,电脑才会发挥出它最大的潜力。于是人们就想方设法的用电线把电脑连接到了一起。

但是简单的连到一起是远远不够的,就好像语言不同的两个人互相见了面,完全不能交流信息。因而他们需要定义一些共通的东西来进行交流,TCP/IP就是为此而生。TCP/IP不是一个协议,而是一个协议族的统称。

里面包括了IP协议,IMCP协议,TCP协议,以及我们更加熟悉的http、ftp、pop3协议等等。电脑有了这些,就好像学会了外语一样,就可以和其他的计算机终端做自由的交流了。

TCP/IP协议分层


TCP/IP协议族按照层次由上到下,层层包装。

「应用层」: 向用户提供一组常用的应用程序,比如电子邮件、文件传输访问、远程登录等。远程登录TELNET使用TELNET协议提供在网络其它主机上注册的接口。TELNET会话提供了基于字符的虚拟终端。文件传输访问FTP使用FTP协议来提供网络内机器间的文件拷贝功能。

「传输层」: 提供应用程序间的通信。其功能包括:

一、格式化信息流;

二、提供可靠传输。为实现后者,传输层协议规定接收端必须发回确认,并且假如分组丢失,必须重新发送。

「网络层」 :负责相邻计算机之间的通信。其功能包括三方面。

一、处理来自传输层的分组发送请求,收到请求后,将分组装入IP数据报,填充报头,选择去往信宿机的路径,然后将数据报发往适当的网络接口。

二、处理输入数据报:首先检查其合法性,然后进行寻径--假如该数据报已到达信宿机,则去掉报头,将剩下部分交给适当的传输协议;假如该数据报尚未到达信宿,则转发该数据报。

三、处理路径、流控、拥塞等问题。

「网络接口层」:这是TCP/IP软件的最低层,负责接收IP数据报并通过网络发送之,或者从网络上接收物理帧,抽出IP数据报,交给IP层。

IP 是无连接的

IP 用于计算机之间的通信。

IP 是无连接的通信协议。它不会占用两个正在通信的计算机之间的通信线路。这样,IP 就降低了对网络线路的需求。每条线可以同时满足许多不同的计算机之间的通信需要。

通过 IP,消息(或者其他数据)被分割为小的独立的包,并通过因特网在计算机之间传送。

IP 负责将每个包路由至它的目的地。

IP地址

每个计算机必须有一个 IP 地址才能够连入因特网。

每个 IP 包必须有一个地址才能够发送到另一台计算机。

网络上每一个节点都必须有一个独立的Internet地址(也叫做IP地址)。现在,通常使用的IP地址是一个32bit的数字,也就是我们常说的IPv4标准,这32bit的数字分成四组,也就是常见的255.255.255.255的样式。

IPv4标准上,地址被分为五类,我们常用的是B类地址。具体的分类请参考其他文档。需要注意的是IP地址是网络号+主机号的组合,这非常重要。

CP/IP 使用 32 个比特来编址。一个计算机字节是 8 比特。所以 TCP/IP 使用了 4 个字节。一个计算机字节可以包含 256 个不同的值:00000000、00000001、00000010、00000011、00000100、00000101、00000110、00000111、00001000 ....... 直到 11111111。现在,你知道了为什么 TCP/IP 地址是介于 0 到 255 之间的 4 个数字。

TCP 使用固定的连接

TCP 用于应用程序之间的通信。

当应用程序希望通过 TCP 与另一个应用程序通信时,它会发送一个通信请求。这个请求必须被送到一个确切的地址。在双方“握手”之后,TCP 将在两个应用程序之间建立一个全双工 (full-duplex) 的通信

这个全双工的通信将占用两个计算机之间的通信线路,直到它被一方或双方关闭为止。

UDP 和 TCP 很相似,但是更简单,同时可靠性低于 TCP。

IP 路由器

当一个 IP 包从一台计算机被发送,它会到达一个 IP 路由器。

IP 路由器负责将这个包路由至它的目的地,直接地或者通过其他的路由器。

在一个相同的通信中,一个包所经由的路径可能会和其他的包不同。而路由器负责根据通信量、网络中的错误或者其他参数来进行正确地寻址。

域名

12 个阿拉伯数字很难记忆。使用一个名称更容易。

用于 TCP/IP 地址的名字被称为域名。w3school.com.cn 就是一个域名。

当你键入一个像 http://www.w3school.com.cn 这样的域名,域名会被一种 DNS 程序翻译为数字。

在全世界,数量庞大的 DNS 服务器被连入因特网。DNS 服务器负责将域名翻译为 TCP/IP 地址,同时负责使用新的域名信息更新彼此的系统。

当一个新的域名连同其 TCP/IP 地址一同注册后,全世界的 DNS 服务器都会对此信息进行更新。

TCP/IP

TCP/IP 意味着 TCP 和 IP 在一起协同工作。

TCP 负责应用软件(比如你的浏览器)和网络软件之间的通信。

IP 负责计算机之间的通信。

TCP 负责将数据分割并装入 IP 包,然后在它们到达的时候重新组合它们。

IP 负责将包发送至接受者。

TCP报文格式


16位源端口号:16位的源端口中包含初始化通信的端口。源端口和源IP地址的作用是标识报文的返回地址。

16位目的端口号:16位的目的端口域定义传输的目的。这个端口指明报文接收计算机上的应用程序地址接口。

32位序号:32位的序列号由接收端计算机使用,重新分段的报文成最初形式。当SYN出现,序列码实际上是初始序列码(Initial Sequence Number,ISN),而第一个数据字节是ISN+1。这个序列号(序列码)可用来补偿传输中的不一致。

32位确认序号:32位的序列号由接收端计算机使用,重组分段的报文成最初形式。如果设置了ACK控制位,这个值表示一个准备接收的包的序列码。

4位首部长度:4位包括TCP头大小,指示何处数据开始。

保留(6位):6位值域,这些位必须是0。为了将来定义新的用途而保留。

标志:6位标志域。表示为:紧急标志、有意义的应答标志、推、重置连接标志、同步序列号标志、完成发送数据标志。按照顺序排列是:URG、ACK、PSH、RST、SYN、FIN。

16位窗口大小:用来表示想收到的每个TCP数据段的大小。TCP的流量控制由连接的每一端通过声明的窗口大小来提供。

窗口大小为字节数,起始于确认序号字段指明的值,这个值是接收端正期望接收的字节。窗口大小是一个16字节字段,因而窗口大小最大为65535字节。

16位校验和:16位TCP头。源机器基于数据内容计算一个数值,收信息机要与源机器数值 结果完全一样,从而证明数据的有效性。检验和覆盖了整个的TCP报文段:这是一个强制性的字段,一定是由发送端计算和存储,并由接收端进行验证的。

16位紧急指针:指向后面是优先数据的字节,在URG标志设置了时才有效。如果URG标志没有被设置,紧急域作为填充。加快处理标示为紧急的数据段。

选项:长度不定,但长度必须为1个字节。如果没有选项就表示这个1字节的域等于0。

数据:该TCP协议包负载的数据。

在上述字段中,6位标志域的各个选项功能如下。

URG:紧急标志。紧急标志为"1"表明该位有效。

ACK:确认标志。表明确认编号栏有效。大多数情况下该标志位是置位的。TCP报头内的确认编号栏内包含的确认编号(w+1)为下一个预期的序列编号,同时提示远端系统已经成功接收所有数据。

PSH:推标志。该标志置位时,接收端不将该数据进行队列处理,而是尽可能快地将数据转由应用处理。在处理Telnet或rlogin等交互模式的连接时,该标志总是置位的。

RST:复位标志。用于复位相应的TCP连接。

SYN:同步标志。表明同步序列编号栏有效。该标志仅在三次握手建立TCP连接时有效。它提示TCP连接的服务端检查序列编号,该序列编号为TCP连接初始端(一般是客户端)的初始序列编号。

在这里,可以把TCP序列编号看作是一个范围从0到4,294,967,295的32位计数器。通过TCP连接交换的数据中每一个字节都经过序列编号。在TCP报头中的序列编号栏包括了TCP分段中第一个字节的序列编号。

FIN:结束标志。

TCP三次握手

所谓三次握手(Three-Way Handshake)即建立TCP连接,就是指建立一个TCP连接时,需要客户端和服务端总共发送3个包以确认连接的建立。在socket编程中,这一过程由客户端执行connect来触发,整个流程如下图所示:


(1)第一次握手:Client将标志位SYN置为1,随机产生一个值seq=J,并将该数据包发送给Server,Client进入SYN_SENT状态,等待Server确认。

(2)第二次握手:Server收到数据包后由标志位SYN=1知道Client请求建立连接,Server将标志位SYN和ACK都置为1,ack=J+1,随机产生一个值seq=K,并将该数据包发送给Client以确认连接请求,Server进入SYN_RCVD状态。

(3)第三次握手:Client收到确认后,检查ack是否为J+1,ACK是否为1,如果正确则将标志位ACK置为1,ack=K+1,并将该数据包发送给Server,Server检查ack是否为K+1,ACK是否为1,如果正确则连接建立成功,Client和Server进入ESTABLISHED状态,完成三次握手,随后Client与Server之间可以开始传输数据了。

简单来说,就是:

1、建立连接时,客户端发送SYN包(SYN=i)到服务器,并进入到SYN-SEND状态,等待服务器确认

2、服务器收到SYN包,必须确认客户的SYN(ack=i+1),同时自己也发送一个SYN包(SYN=k),即SYN+ACK包,此时服务器进入SYN-RECV状态

3、客户端收到服务器的SYN+ACK包,向服务器发送确认报ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手,客户端与服务器开始传送数据。

「SYN攻击」

在三次握手过程中,Server发送SYN-ACK之后,收到Client的ACK之前的TCP连接称为半连接(half-open connect),此时Server处于SYN_RCVD状态,当收到ACK后,Server转入ESTABLISHED状态。

SYN攻击就是Client在短时间内伪造大量不存在的IP地址,并向Server不断地发送SYN包,Server回复确认包,并等待Client的确认,由于源地址是不存在的,因此,Server需要不断重发直至超时,这些伪造的SYN包将产时间占用未连接队列,导致正常的SYN请求因为队列满而被丢弃,从而引起网络堵塞甚至系统瘫痪。

SYN攻击时一种典型的DDOS攻击,检测SYN攻击的方式非常简单,即当Server上有大量半连接状态且源IP地址是随机的,则可以断定遭到SYN攻击了,使用如下命令可以让之现行:

#netstat -nap | grep SYN_RECV

TCP四次挥手

所谓四次挥手(Four-Way Wavehand)即终止TCP连接,就是指断开一个TCP连接时,需要客户端和服务端总共发送4个包以确认连接的断开。在socket编程中,这一过程由客户端或服务端任一方执行close来触发,整个流程如下图所示:


由于TCP连接时全双工的,因此,每个方向都必须要单独进行关闭,这一原则是当一方完成数据发送任务后,发送一个FIN来终止这一方向的连接,收到一个FIN只是意味着这一方向上没有数据流动了,即不会再收到数据了,但是在这个TCP连接上仍然能够发送数据,直到这一方向也发送了FIN。

首先进行关闭的一方将执行主动关闭,而另一方则执行被动关闭,上图描述的即是如此。

(1)第一次挥手:Client发送一个FIN,用来关闭Client到Server的数据传送,Client进入FIN_WAIT_1状态。

(2)第二次挥手:Server收到FIN后,发送一个ACK给Client,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号),Server进入CLOSE_WAIT状态。

(3)第三次挥手:Server发送一个FIN,用来关闭Server到Client的数据传送,Server进入LAST_ACK状态。

(4)第四次挥手:Client收到FIN后,Client进入TIME_WAIT状态,接着发送一个ACK给Server,确认序号为收到序号+1,Server进入CLOSED状态,完成四次挥手。

为什么建立连接是三次握手,而关闭连接却是四次挥手呢?

这是因为服务端在LISTEN状态下,收到建立连接请求的SYN报文后,把ACK和SYN放在一个报文里发送给客户端。

而关闭连接时,当收到对方的FIN报文时,仅仅表示对方不再发送数据了但是还能接收数据,己方也未必全部数据都发送给对方了,所以己方可以立即close,也可以发送一些数据给对方后,再发送FIN报文给对方来表示同意现在关闭连接,因此,己方ACK和FIN一般都会分开发送。

为什么TIME_WAIT状态需要经过2MSL(最大报文段生存时间)才能返回到CLOSE状态?

原因有二:

一、保证TCP协议的全双工连接能够可靠关闭

二、保证这次连接的重复数据段从网络中消失

先说第一点,如果Client直接CLOSED了,那么由于IP协议的不可靠性或者是其它网络原因,导致Server没有收到Client最后回复的ACK。那么Server就会在超时之后继续发送FIN。

此时由于Client已经CLOSED了,就找不到与重发的FIN对应的连接,最后Server就会收到RST而不是ACK,Server就会以为是连接错误把问题报告给高层。

这样的情况虽然不会造成数据丢失,但是却导致TCP协议不符合可靠连接的要求。所以,Client不是直接进入CLOSED,而是要保持TIME_WAIT,当再次收到FIN的时候,能够保证对方收到ACK,最后正确的关闭连接。

再说第二点,如果Client直接CLOSED,然后又再向Server发起一个新连接,我们不能保证这个新连接与刚关闭的连接的端口号是不同的。也就是说有可能新连接和老连接的端口号是相同的。

一般来说不会发生什么问题,但是还是有特殊情况出现:假设新连接和已经关闭的老连接端口号是一样的,如果前一次连接的某些数据仍然滞留在网络中。

这些延迟数据在建立新连接之后才到达Server,由于新连接和老连接的端口号是一样的,又因为TCP协议判断不同连接的依据是socket pair,于是,TCP协议就认为那个延迟的数据是属于新连接的,这样就和真正的新连接的数据包发生混淆了。

所以TCP连接还要在TIME_WAIT状态等待2倍MSL,这样可以保证本次连接的所有数据都从网络中消失。

版权声明:本文来源网络,免费传达知识,版权归原作者所有。如涉及作品版权问题,请联系我进行删除。

来源:https://www.jianshu.com/p/ef892323e68f

猜你喜欢:

数组还能这么玩?

用3个IO口控制6个LED灯,怎么做到的?

在公众号聊天界面回复1024,可获取嵌入式资源;回复 ,可查看文章汇总。

嵌入式大杂烩 专注于嵌入式技术,包括但不限于C/C++、嵌入式、物联网、Linux等编程学习笔记,同时,内包含大量的学习资源。欢迎关注,一同交流学习,共同进步!
评论
  • 前言美的电磁炉作为市场主流品牌,拥有‌C22-WH2237‌、‌MC-E35C02‌等多款热门型号,覆盖家用至商用场景,具备高效聚能与安全保护特性。今天来拆解一个美的电磁炉,给大家分享一下美的电磁炉的内部结构设计,以供学习借鉴。美的多功能电磁炉,型号C21-WK2102,额定功率2100W,额定电压220V~,额定频率50Hz。上壳部分,就是壳体加黑晶板的粘合。说一下黑晶板吧,黑晶板的横向导热率几乎为零,但是纵向导热能力却较强;因此不会通过面板横向传热,也不会使锅具周围的面板发烫,从而使得消费者
    短歌行 2026-05-29 20:27 1337浏览
  •  我们生活在数字时代。 每天扫码支付、刷视频、在社交软件上聊天,无一不涉及到电子信息。“电子”意味着设备需要通电才能工作。手机没电会让人焦虑,电脑关机就与世界断开了连接。“信息”是具体的内容。一段文字、一首歌曲、一张照片、一个闪烁的红灯……这些都是信息。 问题来了:电子设备,究竟是如何处理丰富多彩的人类信息呢?答案是:通过“数字”。 一、万物皆由数,如何把现实世界塞进芯片? 色不异数,数不异色,色即是数,数即是色,受想行识,亦复如是。——改编自《
    嵌入式开发之道 2026-06-03 23:44 1017浏览
  • 本次测试说明以四项指标进行量化测试在相同的测试条件与环境下,我们使用分光辐射亮度计等专业量测设备,针对不同显示技术的多款电视机型进行评估,并以中立客观的立场,依据以下四项指标进行实测与分析,以比较 RGB Mini LED 电视相较于其他技术的画质优势程度。在测试流程、量测以及结果分析过程中,未受到委托方任何干预。测试机型(型号)RGB Mini LED:100ZX1SQuantum Dot + Mini LED: 85Z875R传统机型(广色域 LED):65M550R测试结果① 最大亮度实测
    百佳泰测试实验室 2026-06-05 14:42 1133浏览
  •   知是行的主意,行是知的功夫;知是行之始,行是知之成。——王阳明 在前篇中,我们已经把数字芯片的“四大基石”全部凑齐了:0 和 1(电压高低):代表现实世界的所有信息。逻辑门(与或非、异或):负责做条件判断和计算(组合逻辑)。时钟(CLK 鼓点):负责指挥全军,步调一致。D触发器(DFF/寄存器):负责死守记忆,到点才更新。 让我们从纸上谈兵进入实战,访问在线电路仿真实验网站—— Falstad​ (https:/www.falstad.com/circ
    嵌入式开发之道 2026-06-07 13:16 1138浏览
  •       近期在闲鱼上淘到一个已病退的16G酷刃U盘,这个造型堪称经典,记得它刚出来的时候,曾经在京东买了三个8G的,至今还有一个在用,感觉造型轻薄,质量也是刚刚的。      早先买的U盘表面自己已经磨得不剩一字,这个看着还挺清晰,酷刃(Cruzer Blade),容量16GB,产自马来西亚。      原先的U盘用得好好的没想过要怎么去拆开看看,这个插上电脑上已然毫无反应。秉持着死马当活马医的精神,拆
    lyyinhe_xi 2026-06-11 16:04 689浏览
  • 前言电子密码器是电子银行的安全工具,电子密码器内置密码生成芯片,生成的动态密码可以对电子银行对外支付进行身份认证,客户无需安装任何程序即可在多渠道使用。下面是中国银行中银e令(E‑Token),也常被称为动态口令牌、电子密码器,是网银和手机银行对外转账时的核心安全认证硬件。正面:印有中国银行LOGO、序列号、有效期,LCD屏幕显示6位动态数字口令,并标注安全提示“切勿向任何人泄露动态口令”。​背面:印有银行官网、手机银行网址与客服热线95566。下面开始进行拆解。背面PCB板。正面PCB板。显示
    短歌行 2026-05-29 21:33 1384浏览
  •  概述基于规格书标称参数,AP2400的输入电压范围为5V-150V,最大输出电流能力为6A,是一款面向大功率LED照明场景的降压型恒流驱动芯片,采用SOP8封装,内置抖频与平均电流采样电路,本文对其电气特性与架构设计进行逐项分析。拓扑与控制架构分析AP2400采用固定频率PWM控制的降压恒流拓扑,需外部驱动功率MOS管,支持10mA~6A的宽范围输出电流配置。其控制环路采用平均电流模式采样架构,相较于峰值电流采样方案,可有效降低宽输入电压波动下的恒流偏差,适配电动车、摩托车等供电电压
    世微半导体_千羽 2026-06-01 16:13 1772浏览
  •   传说中上帝7天创造了世界。我们也准备花1周带你从零开始,亲手“造”出能点灯的微型计算机。 为什么要学这个? 科学技术是第一生产力,数字化技术已经成为现代社会的底座。如果你是: 零基础小白:快速入门FPGA/芯片设计,为入行找工作打下基础软件工程师:快速入门FPGA/芯片设计,理解数字化技术的底层原理技术管理者:了解数字技术开发人员干的是哪些事儿,能做出更明智的技术决策投资者/创业者:了解芯片和计算的根本原理,能看透技术趋势的本质 那
    嵌入式开发之道 2026-06-03 23:38 1024浏览
  • 隔离芯片的核心在于其内部的“隔离栅”。不同的“内功心法”——即隔离技术——塑造了各自独特的性能特性。光耦隔离 (Optocoupler - Opto) 利用光作为物理介质传递信号。输入端的LED发光,被输出端的光敏器件(如光电晶体管或光电二极管加放大器)接收并转化为电信号。这项技术成熟且成本相对较低(尤其在简单应用中),具备高隔离电压(可达10kV以上)和良好的抗共模干扰能力。然而,其缺点也比较明显:速度受限于LED开关速度和光生载流子寿命,带宽通常低于10Mbps;功耗较高,因为LED驱动需要
    扎陵半导体_Kyle 2026-05-29 16:11 507浏览
  • 前言变压器是开关电源的核心部分,有磁芯,骨架和线包组成,实现电生磁和磁生电的转换。AC-DC手机电源适配器,个头最大的元件就是变压器了,绕着黄色绝缘胶带。拆下开关电源高频变压器,看一看内部线包是怎么缠绕的。一次侧特写。二次侧特写。剥离外层黄色绝缘胶带后,中间黑色块状为EE型高频铁氧体磁芯,两侧是塑胶绕组骨架,是高频电源变压器核心导磁部件。粗铜导线为主功率绕组(原边/副边大功率线圈),细线多为辅助供电绕组/反馈绕组,引脚焊在骨架侧边金属针脚上。外层黄色玛拉胶带起匝间、层间绝缘防护,拆除后裸露线圈与
    短歌行 2026-06-02 21:21 1999浏览
  • 一、差分探头的原理‌高压差分探头属于功能隔离型探头,但不属于绝对完全隔离的探头‌,这一结论是由它的技术设计和性能特性决定的。又因为高压差分探头能安全地测试高压信号,所以被称作传统意义上的隔离探头。根据测量量程和应用场景的差异,有源差分探头主要分为低压型与高压型两个大类:低压型有源差分探头通常针对毫伏级到百伏级的小信号测量,带宽更高,精度表现更优,但耐压能力有限,一般用于信号完整性测试、低电压接口信号测量等场景;高压型有源差分探头则针对百伏到数千伏的高压场景设计,内置专门的电气隔离模块,兼顾精度与
    ZLPROBE 2026-06-01 15:06 1660浏览
  • 过去两年,我们在大模型上的焦虑往往源于“连接”——网络卡顿、数据泄露、按量付费的账单。但瑞芯微在2025年三季度发布的RK182X,或许能让我们松一口气。这颗全球首款3D封装端侧大模型协处理器,首次在本地实现了7B参数模型的流畅运行(近100 Tokens/s),且能效比提升了6倍。目前,它已悄然导入数百个行业项目,商业化落地速度远超预期。RK182X的出现,印证了一个判断:AI计算正在经历“去中心化”。端侧AI并非云端的附庸。就像PC没有因为互联网消失一样,本地算力因其“实时响应(低延迟)、数
    启扬ARM嵌入式 2026-06-05 09:09 245419浏览
  • 在工业自动化、物联网、电力新能源等领域全速升级的当下,嵌入式核心板早已不是简单的“算力载体”,而是决定设备稳定性、扩展性与落地速度的核心部件。飞凌嵌入式FET153-S核心板,基于全志工业级T153处理器精心打磨,凭借4×A7与RISC-V多核异构架构、成熟Linux系统、工业级品质与全国产化配置,精准击中工控、物联网等场景的开发痛点,成为嵌入式产品迭代的优质选择。 飞凌嵌入式FET153-S核心板的竞争力,首先体现在创新的多核异构计算架构。它搭载全志专为工业场景打造的T153处理器,
    飞凌嵌入式 2026-06-11 15:21 494浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦