计算机网络学习笔记(五):运输层(待更新)

目录

5.1 概述

5.1.1 TCP协议的应用场景

5.1.2 UDP协议的应用场景

5.2 三大关系

5.2.1 传输层协议和应用层协议之间的关系

5.3 用户数据报协议UDP(User Datagram Protocol)

5.3.1 UDP的特点

5.3.2 UDP的首部 

5.4 传输控制协议TCP(Transmission Control Protocol)

5.4.1 TCP的特点

5.4.2 TCP的首部(类比IP的首部)


5.1 概述

5.1.1 TCP协议的应用场景

        TCP为应用层协议提供可靠传输,发送端按顺序发送,接收端按顺序接收,其间发送丢包、乱序,TCP负责重传和排序。下面是TCP的应用场景。

  • 多次交互:客户端程序和服务端程序需要多次交互才能实现应用程序的功能
    • 接收电子邮件的POP3
    • 发送电子邮件的SMTP
    • 传输文件的FTP
  • 数据需要分段传输:应用程序传输的文件需要分段传输
    • 浏览器访问网页:网页中图片和HTML文件需要分段后发送给浏览器
    • QQ传文件

5.1.2 UDP协议的应用场景

  • 数据无需分段传输:客户端程序和服务端程序通信,应用程序发送的数据包不需要分段。
    • DNS域名解析:客户端向DNS服务器发送一个报文解析某个网站的域名,DNS服务器将解析的结果使用一个报文返回给客户端。
  • 实时通信:发送端和接收端需要实时交互,不允许较长延迟(通信时无需建立连接)
    • 语音/视频聊天:即便有几句话因为网络堵塞没听清,也不允许使用TCP等待丢失的报文,等待的时间太长了,就不能愉快的聊天了。
  • 多播或广播通信
    • 学校多媒体机房:老师的电脑屏幕需要教室的学生电脑接收屏幕,在老师的电脑安装多媒体教室服务端软件,在学生的电脑安装多媒体教室客户端软件。老师电脑使用多播地址或广播地址发送报文,学生电脑都能收到。
  • 注:同一个应用程序,可能会使用不同的协议。
    • QQ文字聊天、语音聊天、视频聊天:UDP协议
    • QQ传文件:TCP协议

5.2 三大关系

5.2.1 传输层协议和应用层协议之间的关系

        通常,传输层协议加一个端口号来标识一个应用层协议

  • 常见的应用层协议和传输层协议
    • HTTP默认使用TCP的80端口
    • HTTPS默认使用TCP的443端口(访问安全网站)
    • FTP默认使用TCP的21端口
    • SMTP默认使用TCP的25端口
    • POP3默认使用TCP的110端口
    • Telnet使用TCP的23端口
    • RDP默认使用TCP的3389端口(远程桌面协议)
    • Windows访问共享资源使用TCP的445端口
    • 微软SQL数据库默认使用TCP的1433端口
    • MySQL数据库默认使用TCP的3306端口
    • DNS使用UDP or TCP 的53端口

端口

  • 取值范围:端口用一个16端口号进行标志,允许有65536不同的端口号。
  • 分类:2大类、3小类
    • 服务器端使用的端口号
      • 熟知端口号:0 ~ 1023
      • 登记端口号:1024 ~ 49151,为没有熟知端口号的应用程序使用的。使用这个范围的端口号必须在IANA登记,以防止重复。
    • 客户端使用的端口号
      • 短暂端口号:49152 ~ 65535,留给客户进程选择暂时使用。
      • 当服务器进程收到客户进程的报文时,就知道了客户进程所使用的动态端口号。通信结束后,这个端口号可供其他客户进程以后使用。
  • 作用:端口号只具有本地意义,只是为了标志本计算机应用层中的各进程。在互联网中,不同计算机的相同端口号是没有联系的;同一计算机的不同进程使用不同的端口号(唯一)。
    • 服务器上端口的作用:定位服务器上的服务
      • 服务器给网络中的计算机提供服务,服务器一旦运行某个服务,该服务就会使用TCP/UDP协议的相应端口来侦听客户端的请求、等待客户端的访问,每个服务使用的端口必须唯一。
      • 当不同客户端访问同一服务器上的不同应用时,数据报最终都会到达同一服务器。此时,需要使用服务器上的端口号来定位服务,以便将不同的请求转到相应的服务进行处理。
    • 客户端上端口的作用:确定数据包返回后给哪个客户端实例

  • 注(重要!!!):同一台计算机既可以作为服务端,也可以作为客户端(即服务端和客户端是相对的)。
  • 小结:两个计算机中的进程要互相通信,不仅必须知道对方的端口号为了找到对方计算机中的应用进程) ,而且还要知道对方的 IP 地址为了找到对方的计算机)。

5.3 用户数据报协议UDP(User Datagram Protocol)

5.3.1 UDP的特点

        UDP只在IP的数据报服务之上增加了很少一点的功能:

  • 功能1(复用和分用):使用端口标识不同的应用层协议
    • 注:如果不是为了复用和分用,应用程序完全可以将需要传输的报文交给网络层,而不需要经过传输层UDP。
  • 功能2(差错检测)

  • 面向无连接:发送数据之前不需要建立连接
    • 减少了开销:主机不需要维持复杂的连接状态表(含有许多参数)
      • TCP:主机需要记录所有的TCP连接,可使用命令“netstat”查看(当大量用户同时访问web服务器时,web服务器需要记录所有的会话状态,消耗服务器的资源)
      • UDP:
    • 减少了时延
  • 面向报文:对于应用层交下来的报文,UDP既不合并,也不拆分,而是保留这些报文的边界。UDP一次交付一个完整的报文。

  • 尽最大努力交付/不提供可靠交付
    • 注:UDP本身是不保证可靠的,当发送的数据出现差错时,由发送端重新发送。
  • 不局限于一对一:UDP支持一对一、一对多、多对一和多对多的交互通信(即支持多播、广播
  • 无拥塞控制:网络出现的拥塞不会使源主机的发送速率降低(减少了时延)
    • 实时应用:要求源主机以恒定的速率发送数据,并且允许在网络发生拥塞时丢失一些数据,但却不允许数据有太大的时延
    • 多媒体通信
  • 首部开销小
    • UDP:8个字节
    • TCP :20个字节

5.3.2 UDP的首部 

  • 源端口(选用):根据是否需要对方回信来确定是否使用
    • 需要对方回信:填入源端口号(系统随机产生)
    • 不需要对方回信:全0
  • 目的端口(必用):在终点交付报文时,必须使用(用于确定将该报文交付给上层的哪个具体应用程序)
  • 长度:UDP用户数据报的长度(首部+数据部分)
    • 最小值:8(仅有首部)
  • 检验和:检测UDP用户数据报在传输中是否有错(有错就丢弃)
    • 注:为了计算校验和,此处引入“伪首部”共同参与计算

5.4 传输控制协议TCP(Transmission Control Protocol)

5.4.1 TCP的特点

  • 面向连接:发送数据之前需要建立连接(三次握手),用于协商参数(窗口大小、最大报文段长度MSS、是否支持选择性确认等)
  • 面向字节流:虽然应用程序和TCP的交互是一次一个数据块,但TCP把应用程序交下来的数据看成仅仅是一连串无结构的字节流。TCP中的“流”(steam)指的是流入到进程或从进程流出的字节序列。
    • 数据块不同:TCP不保证接收方应用程序收到的数据块发送方应用程序发出的数据块具有对应大小的关系
    • 字节流相同:TCP保证接收方应用程序收到的字节流必须和发送方应用程序发出的字节流完全一样
  • 提供可靠交付:通过TCP连接传送的数据,无差错、不丢失、不重复且按序发送和接收。(为了在无连接的、不可靠的IP网络服务基础之上提供可靠交付的服务,TCP在IP的数据报服务基础之上,增加了保证可靠性的一系列措施。)

  • 局限于一对一:每一条TCP连接只能有两个端点(end point),只能是点对点的(一对一)(即不支持多播、广播
  • 全双工通信:一旦通信双方建立连接,就能基于此连接进行双向通信。

TCP中“面向流”的概念

TCP中“连接”的概念

  • TCP连接的端点套接字(socket)/插口
    • 套接字由IP地址和端口号构成,表示TCP连接的一端。
    • 注1:TCP 连接的端点不是主机,不是主机的IP 地址,不是应用进程,也不是运输层的协议端口。
    • 注2:socket有多种不同的意思
      • 应用编程接口API称为socket API,简称为socket
      • socket API中使用的一个函数名也叫作socket
      • 调用socket函数的端点称为socket
      • 调用socket函数时其返回值称为socket描述符,简称为socket
      • 在操作系统内核中连网协议的Berkeley实现,称为socket实现

  • TCP连接:每一条TCP连接唯一地被通信两端的两个端点(即两个套接字)所确定。(每一条TCP连接有两个端点)
    • TCP 连接就是由协议软件所提供的一种抽象。
    • TCP 把连接作为最基本的抽象。
    • 同一个IP地址可以出现在多个不同的TCP连接中。
    • 同一个端口号可以出现在多个不同的TCP连接中
    • 示例:现有两个浏览器同时访问web服务器,建立的连接如下所示
      • 连接1:{(202.108.22.5:80), (192.168.0.2:55262)}
      • 连接2:{(202.108.22.5:80), (192.168.0.3:59379)}
      • 可见,同一个IP地址202.108.22.5出现在两条不同的连接中;同一个端口号80也出现在两条不同的连接中。

5.4.2 TCP的首部(类比IP的首部)

  • 源端口(2字节)、目的端口(2字节):标识不同的应用层协议
  • 序号(4字节):本报文段所发送数据的第一个字节在整个数据(文件)中的第几个字节
    • 取值:[0, 2^{31}-1],共2^{32}个序号
    • 最大值2^{32}= 4294967296 byte = 4194304 KB = 4096 MB = 4 GB(当传输的文件大于4GB时,序号需要从0又开始编号)
  • 确认号(4字节):接收端期望收到发送端下一个报文段的第一个数据字节的序号
    • 一旦建立TCP连接,通信双方可以互相发送数据。当A给B发送数据后,B可以给A回复确认,也可以回复确认和发送数据。
    • BA回复确认(不发送数据):数据报中仅有TCP首部(不得不为了确认而单独产生确认数据报
    • BA回复确认和发送数据:数据报中有TCP首部和需要发送的数据(发送数据时,顺便携带确认号,无需单独产生确认数据报

  • 数据偏移/首部长度(4)TCP报文段的数据起始处距离TCP报文段的起始处有多远
    • 最大值 → 1111 = 15个单位(一个单位为4字节) = 60字节
    • 数据偏移的最大值为60字节,换言之可变部分的最大长度为40字节(固定部分的长度为20字节)
    • 由于首部包含可变部分,其长度并不是固定的,因此必须声明首部长度,以便接收方区分首部和数据
  • 标志位(12)
    • 保留(6):保留为今后使用(目前置为0)
    • 紧急URG(urgent):当URG=l时,“紧急指针”字段有效
      • 报文段有紧急数据,应尽快传送,而不要按照原来的排队顺序来传送。
    • 确认ACK(acknowlegment):当ACK=1时,“确认号”字段才有效
      • TCP规定,在建立连接后,所有传送的报文段都必须把ACK设置1。
    • 推送PSH(push):当两个应用进程进行交互式的通信时,有时一端的应用进程希望在键入一个命令后立即就能收到对方的响应。在这种情况下,TCP就可以使用推送操作。
      • 案例分析:当FTP客户端给FTP服务器上传文件时,在传输过程中,客户端突然中断上传,此时将该命令封装到数据段中(推送标志位置为1)。服务器收到该数据段后,发现推送标志位为1,会立刻处理该数据段,而不必排队等待。
    • 复位RST(reset):当RST=l时,表明TCP连接中出现严重差错(如由于主机崩溃或其他原因),必须释放连接,然后再重新建立传输连接
    • 同步SYN(synchronization):在连接建立时用来同步序号。
    • 终止FIN(finish):当FIN=1时,表明此报文段的发送方的数据己发送完毕,并要求释放传输连接
    • 注:紧急URG和推送PSH通常一起使用;确认ACK、同步SYN和终止FIN通常一起使用。
  • 窗口(16):接收方告诉发送方,从本报文段首部中的确认号算起,接收方目前允许对方发送的数据量
    • 取值:[0, 216-1]之间的整数(单位是字节)
    • TCP协议的流量控制功能是通过调整窗口的大小来实现的:
      • 当网络拥塞或接收端处理速度较慢时,接收端可将窗口值调小
      • 当网络顺畅或接收端处理速度较快时,接收端可将窗口值调大
  • 检验和(16):检验的范围包括首部和数据
  • 紧急指针(16):本报文段中的紧急数据的字节数(紧急数据结束后就是普通数据
  • 选项(长度可变)
    • 最大值:40字节
    • 常见选项
      • 最大报文段长度(Maximum Segment Size, MSS):TCP最初只规定了一种选项
      • 选择确认(Selective Acknowledgement, SACK)
    • :选项长度需要为4字节的整数倍,否则需要填充

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/187091.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

系列一、Shiro概述

一、概述 Shiro是一款主流的Java安全框架,不依赖任何容器,可以运行在JavaSE 和 JavaEE项目中,它的主要作用是对访问系统的用户进行身份认证、授权、会话管理、加密等操作。 一句话:Shiro是一个用来解决安全管理的系统框架&#x…

MVCC中的可见性算法

在之前的文章 MVCC详解-CSDN博客中我们已经介绍过了MVCC的原理(read viewundo log),今天来详细的说一下readview的匹配规则(可见性算法) 隔离级别在RC,RR的前提下 Read View是如何保证可见性判断的呢&#…

一篇带你精通php

华子目录 什么是phpphp发展史平台支持和数据库支持网站静态网站和动态网站的区别静态网站动态网站的特点 关键名词解析服务器概念IP的概念域名DNS端口 web程序的访问流程静态网站访问流程动态网站访问流程 php标记脚本标记标准标记(常用) php注释 什么是…

[LeetCode]-225. 用队列实现栈

目录 225. 用队列实现栈 题目 ​思路 代码 225. 用队列实现栈 225. 用队列实现栈 - 力扣(LeetCode)https://leetcode.cn/problems/implement-stack-using-queues/description/ 题目 请你仅使用两个队列实现一个后入先出(LIFO&#xff0…

【Servlet】 三

本文主要介绍了基于serlvet的表白墙项目的编写. (附完整代码) 一.JS基础 作为后端开发,对于前端的要求是能前端代码能看懂七七八八 . JS是一个动态弱类型的编程语言 1. let/war定义变量 (推荐使用let) 2.querySelector是浏览器提供api , 能够获取到页面的元素的 (js的目的就…

原语:串并转换器

串并转换器OSERDESE2 可被Select IO IP核调用。 IP配置方法:(待续) OSERDESE2允许DDR功能 参考: FPGA原语学习与整理第二弹,OSERDESE2串并转换器 - 知乎 (zhihu.com) 正点原子。 ISERDESE2原语和OSERDESE2原语是串…

阿里云99元的主机到底怎么样?

我是卢松松,点点上面的头像,欢迎关注我哦! 在云栖大会上,阿里云推出了一款绝对超级超值的99元云服务器,并号称是11月销量王。什么?云栖大会11月2号结束的,你就号称11月销量王,这是未卜先知啊。…

C# OpenCvSharp 通过特征点匹配图片

SIFT匹配 SURF匹配 项目 代码 using OpenCvSharp; using OpenCvSharp.Extensions; using System; using System.Collections.Generic; using System.Drawing; using System.Linq; using System.Text.RegularExpressions; using System.Windows.Forms; using static System.Net…

Spring Boot中配置多个数据源

配置数据源实际上就是配置多个数据库,在一个配置文件中配置多个数据库,这样做主要的好处有以下几点: 数据库隔离:通过配置多个数据源,可以将不同的业务数据存储在不同的数据库中,实现数据的隔离。这样可以…

Leetcode—637.二叉树的层平均值【简单】

2023每日刷题(二十五) Leetcode—637.二叉树的层平均值 BFS实现代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/ /*** Note: The returned array mu…

vscode文件跳转(vue项目)

在 .vue 文件中,点击组件名打开 方式1: 在 vue 组件名上,桉住ctrl 鼠标左键 // 重新打开一个tab 方式2: 在 vue 组件名上,桉住ctrl shift 鼠标左键 // 在右侧拆分,并打开一个tab .vue文件的跳转 按住 …

漏刻有时百度地图API实战开发(1)华为手机无法使用addEventListener click 的兼容解决方案

漏刻有时百度地图API实战开发(1)华为手机无法使用addEventListener click 的兼容解决方案漏刻有时百度地图API实战开发(2)文本标签显示和隐藏的切换开关漏刻有时百度地图API实战开发(3)自动获取地图多边形中心点坐标漏刻有时百度地图API实战开发(4)显示指定区域在移动端异常的解…

龙芯loongarch64服务器编译安装scipy

前言 根据我之前的文章介绍,龙芯loongarch64服务器中的很多python依赖包安装有问题,发现其中安装的"scikit-learn"就无法正常使用,所有这里在 pip3 install scikit-learn -U -i https://pypi.tuna.tsinghua.edu.cn/simple 的时候发现"scipy"就无法正常…

轻松下载网页音频和视频

在网页上看到好看的视频或者听到的音乐想保存,让我来教你(仅供学习) 注意:有极少部分的网站视频经过加密,无法下载 一、视频下载 1.打开视频网页 2.右键“检查” 3.刷新网页 4.按照下图中步骤操作 5.把复制的链接放…

数字化工厂管理系统的三个关键技术是什么

随着科技的飞速发展,数字化工厂管理系统已经成为了现代制造业的重要发展方向。数字化工厂管理系统通过充分运用建模技术、仿真技术和单一数据源技术,实现了产品设计和生产的虚拟化,为制造业带来了前所未有的效率和创新能力。本文将深入探讨这…

k8s configMap挂载(项目配置文件放到configMap中,不同环境不同配置)

背景说明 项目对接配置文件加密,比如数据库密码、redis密码等。但是密文只能放到指定的配置文件中(important.properties),该配置文件又不能接收环境变量,所以就很难区分不同环境的不同配置(不同环境的数据库密码、redis密码一般…

Gui基础使用之项目部署

🎬 艳艳耶✌️:个人主页 🔥 个人专栏 :《Spring与Mybatis集成整合》《Vue.js使用》 ⛺️ 越努力 ,越幸运。 1.gui图形化界面的使用 1.1 前期准备 新建仓库,具体操作如下: 初始化readme文件&…

软件测试面试会问哪些问题?

软件测试面试,一般会被问到下面这九类问题。 1、基础问题 2、Linux命令 3、数据库 4、功能测试 5、Python基础 6、接口测试 7、自动化测试 8、性能测试 9、人事问题 接下来,以上9类问题,我都会分别结合2个案例,附上答案&#xff0…

Banana Pi BPI-M6(Raspberry Pi 5 替代品)初始设置及固件烧录

Banana Pi BPI-M6:初始设置和镜像烧录 Banana Pi BPI-M6 的首次测试 在上一篇文章中,我比较了Banana Pi BPI-M6和Raspberry Pi 5的硬件特性。两者都拥有出色的硬件技术,在性能方面应该不会有太大的问题。 今天我想测试一下 Banana Pi。作为…

阿里云双11优惠云服务器99元一年,4年396元

阿里云99元服务器新老用户均可以买,你没看错,老用户可以买,活动页面 aliyunfuwuqi.com/go/aliyun 配置为云服务器ECS经济型e实例、2核2G、3M固定带宽、40G ESSD Entry云盘,并且续费不涨价,原价99元即可续费&#xff0c…