「作者主页」:士别三日wyx
「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者
「专栏简介」:此文章已录入专栏《计算机网络零基础快速入门》

传输层
传输层负责
「进程」和
「进程」之间的数据传输。
网络层根据IP地址将数据从源主机传输到目的主机,主机可以提供很多服务,比如Web服务、FTP服务等,需要使用 IP地址+端口号 来区分不同的服务。
因此,我们得先知道端口是什么。
端口(port)是设备与外界通信的出口,就像进出房子的门。
一台主机有65536个端口,用端口号来标记,范围是 0~65535 ,其中:
当主机收到数据包后,会根据报文首部的目的端口号,把数据发送到对应的端口;等数据处理完毕后,再根据报文首部的源端口号,原路返回。
比如,主机收到一个数据包,报文首部的目的端口号是80,传输层就会把这个数据包交给80端口对应的Web服务去处理。
那么,数据是怎么在端口之间进行传输的呢?答案是数据传输协议。
传输层提供了两种数据传输协议:TCP和UDP。
UDP协议(User Datagram Portocol),也叫「用户数据报协议」,是一种无连接的数据传输协议。
UDP协议有三个特点:无连接、不可靠、传输速度快。
1)「无连接」是指,发送方和接收方不需要建立连接,就能直接传输数据。
2)「不可靠」是因为,UDP使用报文首部的检验值来保证数据的安全。发送方通过算法计算出校验值,接收方收到后再重新计算,如果数据被篡改或者被噪音损坏,校验值就会发生变化,UDP就可以检查出错误。但UDP只检错而不纠错,出错的信息会被扔掉或者发送警告信息。并且UDP不对数据进行分组和排序,不能判断数据是否安全完整的传送,可靠性较低。
3)「传输速度快」是相对于TCP来说的,UDP的头部只有8个字节(TCP有20个字节),不包含控制信息,只是尽最大的努力去传输数据,因此速度很快。
由于不可靠但速度快的特点,UDP适合视频和音频这种对数据完整性要求不高的应用。
UDP的报文在IP数据报的数据部分,如下图所示:

UDP报文分为首部和数据两个部分,首部包含4个字段:源地址、目的地址、UDP长度、校验和。

TCP报文同样保存在IP数据报的数据部分,占用20个字节,比UDP报文多了一些控制字段。

TCP是基于连接的传输协议,传输过程分为三个阶段:建立连接、数据传输、释放连接。
TCP在传输数据前需要建立连接,也就是我们常说的三次握手,过程如下:

下面是Wireshark抓取的TCP三次握手数据包,重点看我圈中的地方:

首先解释一下里面几个关键字的含义:
第一次握手:客户端发送一个SYN,随机生成一个发送序列号 Seq=x,服务器看到SYN就会知道,这是一个建立连接的请求。
第二次握手:服务器响应了一个ACK和一个SYN,把收到的Seq的值加上1,放到Ack里面(Ack = x+1),客户端可以根据这个Ack的值判断连接是否有误,然后再随机生成一个Seq=y。
第三次握手:客户端发送一个ACK,把响应回来的Seq的值加上1,放到Ack里面(Ack = y+1),服务器同样可以根据这个Ack的值判断连接是否有误,如果没有错误就建立连接,开始传输数据。
数据传输完成后,需要释放连接;
由于TCP是「全双工」通信,两个方向的连接都得单独关闭,因此,需要两次请求和响应,也就是我们常说的四次挥手,过程如下:
为什么建立连接是三次,关闭连接却是四次?
TCP是全双工通信,有两条连接,当一方发送完数据后,并不能确定对方是不是也发送完了数据,因此只能关闭单方向的连接,等到对方也发送完数据后,再关掉另一个方向的连接。
TCP协议的可靠主要依赖三个机制:分包、排序确认、超时重传。
1)TCP将应用层的数据拆分成多个数据包,给每个包一个「序号」,接收方可以根据序号保证数据的顺序。
2)TCP使用首部「校验和」字段保证数据的准确性,发送和接收时都要计算校验和,校验和一致则判定数据正常,接收方就响应一个确认(ACK),表示数据已经收到了。
3)如果在规定时间内,发送方没有收到接收方的确认(ACK),则判定数据丢失,重新发送这个数据包,也就是「超时重传」。
这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,
SPI接收数据左移一位问题目录SPI接收数据左移一位问题一、问题描述二、问题分析三、探究原理四、经验总结最近在工作在学习调试SPI的过程中遇到一个问题——接收数据整体向左移了一位(1bit)。SPI数据收发是数据交换,因此接收数据时从第二个字节开始才是有效数据,也就是数据整体向右移一个字节(1byte)。请教前辈之后也没有得到解决,通过在网上查阅前人经验终于解决问题,所以写一个避坑经验总结。实际背景:MCU与一款芯片使用spi通信,MCU作为主机,芯片作为从机。这款芯片采用的是它规定的六线SPI,多了两根线:RDY和INT,这样从机就可以主动请求主机给主机发送数据了。一、问题描述根据从机芯片手
项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU
我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我
给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in
给定两个大小相等的数组,如何找到不考虑位置的匹配元素的数量?例如:[0,0,5]和[0,5,5]将返回2的匹配项,因为有一个0和一个5共同;[1,0,0,3]和[0,0,1,4]将返回3的匹配项,因为0有两场,1有一场;[1,2,2,3]和[1,2,3,4]将返回3的匹配项。我尝试了很多想法,但它们都变得相当粗糙和令人费解。我猜想有一些不错的Ruby习惯用法,或者可能是一个正则表达式,可以很好地回答这个解决方案。 最佳答案 您可以使用count完成它:a.count{|e|index=b.index(e)andb.delete_at
Ruby中如何“一般地”计算以下格式(有根、无根)的JSON对象的数量?一般来说,我的意思是元素可能不同(例如“标题”被称为其他东西)。没有根:{[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]}根包裹:{"posts":[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]} 最佳答案 首先,withoutroot代码不是有效的json格式。它将没有包
目标我正在尝试计算自给定日期以来周的距离,而无需跳过任何步骤。我更喜欢用普通的Ruby来做,但ActiveSupport无疑是一个可以接受的选择。我的代码我写了以下内容,这似乎可行,但对我来说似乎还有很长的路要走。require'date'DAYS_IN_WEEK=7.0defweeks_sincedate_stringdate=Date.parsedate_stringdays=Date.today-dateweeks=days/DAYS_IN_WEEKweeks.round2endweeks_since'2015-06-15'#=>32.57ActiveSupport的#weeks
文章目录一、项目场景二、基本模块原理与调试方法分析——信源部分:三、信号处理部分和显示部分:四、基本的通信链路搭建:四、特殊模块:interpretedMATLABfunction:五、总结和坑点提醒一、项目场景 最近一个任务是使用simulink搭建一个MIMO串扰消除的链路,并用实际收到的数据进行测试,在搭建的过程中也遇到了不少的问题(当然这比vivado里面的debug好不知道多少倍)。准备趁着这个机会,先以一个很基本的通信链路对simulink基础和相关的debug方法进行总结。 在本篇中,主要记录simulink的基本原理和基本的SISO通信传输链路(QPSK方式),计划在下篇记
技术选型1,前端小程序原生MINA框架cssJavaScriptWxml2,管理后台云开发Cms内容管理系统web网页3,数据后台小程序云开发云函数云开发数据库(基于MongoDB)云存储4,人脸识别算法基于百度智能云实现人脸识别一,用户端效果图预览老规矩我们先来看效果图,如果效果图符合你的需求,就继续往下看,如果不符合你的需求,可以跳过。1-1,登录注册页可以看到登录页有注册入口,注册页如下我们的注册,需要管理员审核,审核通过后才可以正常登录使用小程序1-2,个人中心页登录成功以后,我们会进入个人中心页我们在个人中心页可以注册人脸,因为我们做人脸识别签到,需要先注册人脸才可以进行人脸比对,进