计算机网络知识总结(四)

传输层

一、传输协议概述

1、进程之间的通信

传输层向它上面的应用层提供通信服务,它属于面向通信部分的最高层,同时也是用户功能中的最低层。当网络的边缘部分中的两个主机使用网络的核心部分的功能进行端到端的通信时,只有主机的协议栈才有传输层,而网络核心部分中的路由在转发分组时都只用到下三层的功能。
从IP层来说,通信的两端是两个主机,IP数据报的首部明确地标志了这两个主机的IP地址,但真正进行通信的实体是在主机中的进程,是这个主机中的一个进程和另一个主机中的一个进程在交换数据(即通信)。IP协议虽然能把分组送到目的主机,但是这个分组还停留在主机的网络层而没有交付给主机中的应用程序。从传输层的角度看,通信的真正端点并不是主机而是主机中的进程。

传输层有一个很重要的功能——复用(multiplexing)和分用(demultiplexing)。“复用”指在发送方不同的应用进程都可以使用同一个传输层协议传送数据,而“分用”指接收方的传输层在剥去报文的首部后能够把这些数据正确交付到目的应用进程。
网络层和传输层之间有明显的区别。网络层是为主机之间提供逻辑通信,而传输层为应用进程之间提供端到端的逻辑通信。

传输层还要对收到的报文进行差错检测(注意网络层的IP数据报首部中的检验和字段,只检验首部是否出现差错而不检查数据部分)。

根据应用程序的不同需求,传输层需要有两种不同的传输协议,即面向连接的TCP和无连接的UDP。当传输层采用面向连接的TCP协议时,尽管下面的网络是不可靠的(只提供尽最大努力服务),但这种逻辑通信信道就相当于一条全双工的可靠信道。但当传输层采用无连接的UDP协议时,这种逻辑通信信道仍然是一条不可靠信道

2、传输层的两个主要协议

按照OSI的术语,两个对等传输实体在通信时传送的数据单位叫作传输协议数据单元TPDU(Transport Protocol Data Unit)。但在TCP/IP体系中,则根据所使用的协议是TCP或UDP,分别称之为TCP报文段(segment)或UDP用户数据报

UDP在传送数据之前不需要先建立连接。远地主机的传输层在收到UDP报文后,不需要给出任何的确认。虽然UDP不提供可靠交付,但在某些情况下UDP却是一种最有效的工作方式。

TCP则提供面向连接的服务。在传送数据之前必须先建立连接,数据传送结束后要释放连接。TCP不提供广播或多播服务。由于TCP要提供可靠的、面向连接的传输服务,所以协议数据单元的首部增大很多,还要占用许多的处理及资源。

下表给出一些应用和应用层协议主要使用的传输层协议(UDP或TCP):
在这里插入图片描述

3、传输层的端口

传输层从IP层收到数据后必须交付给指明的应用进程,所以给应用层的每一个应用进程赋予一个非常明确的标志是至关重要的。解决的方法就是在传输层使用协议端口号(protocol port number),或通常简称为端口(port)。也就是说,虽然通信的终点时应用进程,但我们只要把传送的报文交到目的主机的某一个合适的目的端口,剩下的工作(即最后交付给目的进程)就由TCP来完成。这种在协议栈层间抽象的协议端口是软件端口,和硬件端口不是同一概念。硬件端口是不同硬件设备进行交互的接口,而软件端口是应用层的各种协议进程与传输实体进行层间交互的一种地址。

传输层的端口号共分为下面的两大类:

  • 服务端使用的端口号

此处又分为两类,最重要的一类叫做熟知端口号(well-known port number)或系统端口号,数值为0~1023。IANA把这些端口号指派给了TCP/IP最重要的一些应用程序,让所有的用户都知道,当一种新的应用程序出现后,IANA必须为它指派一个熟知端口,否则因特网上的其他应用进程就无法和它通信,一些常用的熟知端口号如下表:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TvBxVcvO-1591322156679)(/Users/ss/Documents/计算机网络/常用端口号.png)]
另一类叫做登记端口号,数值为1024~49151。这类端口号是为没有熟知端口号的应用程序使用的。使用这类端口号必须在IANA按照规定的手续登记,以防止重复。

  • 客户端使用的端口号

数值为49152~65535。由于这类端口号仅在客户进程运行时才动态选择,因此又叫做短暂端口号。这类端口号是留给客户进程选择暂时使用。当服务器进程收到客户进程的报文时,就知道了客户端所使用的端口号,因而可以把数据发送给客户进程。通信结束后,刚才已使用过的客户端口号就不复存在。这个端口号就可以供其他客户进程以后使用。

二、用户数据报协议UDP

1、UDP概述

用户数据报协议UDP只在IP的数据报服务之上增加很少一点的功能,这就是复用和分用的功能以及差错检测的功能。UDP的主要特点是:

  • UDP是无连接的,减少了开销和发送数据之前的时延;
  • UDP使用尽最大努力交付
  • UDP是面向报文的。发送方的UDP对应用程序交下来的报文,在添加首部后就向下交付给IP层。UDP对应用层交下来的报文,既不合并,也不拆分,而是保留这些报文的边界。也就是说,UDP一次交付一个完整的报文。

UDP的优点如下:

  • UDP没有拥塞处理控制,因此网络出现的拥塞不会使源主机的发送速率降低。这对某些实时应用很重要的,如IP电话、实时视频会议等,允许网络发生拥塞时丢失一些数据,但不允许数据有太大的时延。但也可能引发严重的拥塞问题。
  • UDP支持一对一、一对多、多对一和多对多的交互通信。
  • UDP的首部开销小,只有8个字节,比TCP的20个字节的首部要短。

2、UDP的首部格式

用户数据报UDP有两个字段:数据字段和首部字段。首部字段很简单,只有8个字节,如图1所示,由四个字段组成,每个字段的长度都是两个字节。各字段意义如下:

  • 源端口 源端口号。在需要对方回信时选用。不需要时可用全0。
  • 目的端口 目的端口号。这在终点交付报文时必须使用到。
  • 长度 UDP用户数据报的长度,其最小值是8(仅有首部)。
  • 检验和 检验UDP用户数据报在传输中是否有错。有错就丢弃。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eBnkV50t-1591322156681)(/Users/ss/Documents/计算机网络/UDP.png)]

UDP用户数据报首部中检验和的计算方法有些特殊。在计算检验和时,要在UDP用户数据报之前增加12个字节的伪首部。这个伪首部只是在计算检验和时,临时添加在UDP用户数据报前面,得到一个临时的UDP用户数据报。伪首部既不向下传送也不向上递交。UDP的检验和是把首部和数据部分一起检验

伪首部的第3字段是全零,第4个字段是IP首部中的协议字段的值,对于UDP,此协议字段值是17.第5个字段是UDP用户数据报的长度。因此UDP的检验和既检查了UDP用户数据报的源端口号和目的端口号以及UDP用户数据报的数据部分,又检查了IP数据报的源IP地址和目的地址。

三、传输控制协议TCP概述

1、TCP最主要的特点

  • TCP是面向连接的传输层协议。应用程序在使用TCP协议之前,必须先建立TCP连接。在传送数据完毕后,必须释放已经建立的TCP连接。
  • 每一条TCP连接只能有两个端点(endpoint),每一条TCP连接只能是点对点的(一对一)。
  • TCP提供可靠交付的服务,也就是无差错、不丢失、不重复、按序到达。
  • TCP提供全双工通信。TCP允许通信双方的应用进程在任何时候都能发送数据。TCP连接的两端都设有发送缓存和接收缓存,用来临时存放双向通信的数据。
  • 面向字节流。虽然应用程序和TCP的交互是一次一个数据块(大小不等),但TCP把应用程序交下来的数据看成仅仅是一连串的无结构的字节流。

TCP和UDP在发送报文时所采用

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值