TCP: 传输控制协议

TCP: 传输控制协议

  • TCP的服务
  • TCP 的首部
  • 小结

本系列文章旨在巩固网络编程理论知识,后续将结合实际开展深入理解的文章。

TCP的服务

T C P和U D P都使用相同的网络层(I P),T C P却向应用层提供与U D P完全不同的服务。
T C P提供一种面向连接的、可靠的字节流服务

  • 面向连接意味着两个使用T C P的应用(通常是一个客户和一个服务器)在彼此交换数据之前必须先建立一个T C P连接。
  • T C P通过一系列方式来提供可靠性
    • 超时及重传策略
    • 保序
    • 流量控制
  • T C P不在字节流中插入记录标识符,将这称为字节流服务(byte stream service)。

TCP 的首部

T C P数据被封装在一个I P数据报中:
在这里插入图片描述

下图为T C P首部的数据格式。如果不计任选字段,它通常是2 0个字节。
在这里插入图片描述

  1. 每个T C P段都包含源端和目的端的端口号,用于寻找发端和收端应用进程。这两个值加上I P首部中的源端I P地址和目的端I P地址唯一确定一个T C P连接。即,四元组(s:ip+port, t:ip+port)唯一确定一个TCP连接。有时,一个I P地址和一个端口号也称为一个插口( s o c k e t)。

  2. 序号用来标识TCP报文段中的数据字节流,它表示在这个报文段中的的第一个数据字节。如果将字节流看作在两个应用程序间的单向流动,则 T C P用序号对每个字节进行计数。序号是32 bit的无符号数,序号到达2^32-1后又从0开始。

  3. 同步SYN:同步SYN=1表示这是一个连接请求或连接接受报文

  4. 既然每个传输的字节都被计数,确认序号:占4字节,表示接收方期望收到的下一个字节的序列号。因此,确认序号应当是上次已成功收到数据字节序号加 1。只有ACK=1时,确认序号字段才有效。

  5. 发送A C K无需任何代价,因为32 bit的确认序号字段和A C K标志一样,总是T C P首部的一部分。因此,我们看到一旦一个连接建立起来,这个字段总是被设置, A C K标志也总是被设置为1

  6. 推送PSH:接收TCP收到PSH=1的报文段,就尽快地交付接收应用进程

  7. 复位RST:当RST=1时,表明TCP连接中出现严重差错

  8. T C P的流量控制由连接的每一端通过声明的窗口大小来提供

  9. 终止FIN:用来释放一个连接

  10. 检验和:占2字节,检验和覆盖了整个的T C P报文段:T C P首部和T C P数据。这是一个强制性的字段,由发端计算和存储,并由收端进行验证。

  11. 紧急指针:占16位,指出在本报文段中紧急数据共有多少个字节

  12. 选项:长度可变,包括最大报文段长度MSS等

注意:确认序号ack和标志位中的ACK不是一个东西哦!

小结

T C P将用户数据打包构成报文段;它发送数据后启动一个定时器;另一端对收到的数据进行确认,对失序的数据重新排序,丢弃重复数据; T C P提供端到端的流量控制,并计算和验证一个强制性的端到端检验和。

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

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

相关文章

【已解决】Python报错:AttributeError: module ‘json‘ has no attribute ‘loads‘

😎 作者介绍:我是程序员行者孙,一个热爱分享技术的制能工人。计算机本硕,人工制能研究生。公众号:AI Sun,视频号:AI-行者Sun 🎈 本文专栏:本文收录于《AI实战中的各种bug…

离散数学上机报告

一、 实验题目(编程上机题) (1) 从键盘分别对P、Q输入数据1、0,分别输出P∧Q、P∨Q、P→Q的逻辑结果值。 (2) 从键盘输入无向图的邻接矩阵,判断输出该图结点最大度数、最小度数。 &a…

synchronized关键字和ReentrantLock在不同jdk版本中性能哪个高?该怎么选择呢?

synchronized关键字和ReentrantLock在不同JDK版本中的性能差异经历了显著的变化。早期,在JDK 1.5及以前的版本中,ReentrantLock通常提供了更好的性能,主要是因为synchronized关键字的实现较为简单,没有太多的优化,导致…

图片如何去水印,分享4个小妙招,手把手教会你!

作为一个经常逛社区网站下载表情包、头像的人,遇到的一个大难题就是图片有水印。如何才能快速去除水印?询问了一圈身边朋友,搜集了各种资料,小编整理了4个超好用的方法。 如果大家和小编一样,能坐着就不站着&#xff0…

PHP 高频面试题

PHP 初级面试题及详细解答 1. 什么是 PHP,PHP 的全称是什么? 解答: PHP 是一种流行的开源脚本语言,特别适合用于 web 开发并可以嵌入 HTML。PHP 的全称是 “PHP: Hypertext Preprocessor”,它最初代表的是 “Personal Home Page…

Python简单实现自动识别并填加验证码

实现自动识别网页中的验证码并填写,需要结合使用网络爬虫技术、图像识别(OCR),以及可能的浏览器自动化工具(如Selenium)。以下简单实现一下如何结合这些技术来实现这一目标: 步骤 1: 获取验证码…

Rust单元测试、集成测试

单元测试、集成测试 在了解了如何在 Rust 中写测试用例后,本章节我们将学习如何实现单元测试、集成测试,其实它们用到的技术还是上一章节中的测试技术,只不过对如何组织测试代码提出了新的要求。 单元测试 单元测试目标是测试某一个代码单…

细说QT表格类复杂控件用法(TableView/TreeView/ListView)

文章目录 表格类控件样式控制设置表格类控件指示器样式表格类控件嵌入自定义控件表格控件禁用列拖动设置列宽和行高表格选中操作数据库+表格控件选中操作和选中样式Qt提供了几种基于模型/视图(Model/View)架构的表格类控件,主要包括QTableView、QTreeView和QListView。这些控件…

Makefile中lastword的用法

Makefile中lastword的用法 在 Makefile 中,lastword 函数用于返回参数列表中的最后一个单词(以空格或制表符分隔)。它的基本语法如下: lastword words其中,words 是一个包含多个单词的参数列表,可以是变量…

一次DC1靶机的渗透测试

确定目标IP: nmap -sP 192.168.11.1/24 发现目标机器 扫描开放的端口: nmap -T4 -A -v 192.168.11.145 发现开放了一个80端口,并且给出了是Drupal的管理系统 浏览器访问这个服务: 因为这是一个Drupal的管理系统,那么…

Pandas基础应用:数据处理与分析的利器

概括 在数据科学领域,Pandas无疑是一个强大的数据处理和分析工具。它提供了高效、灵活的数据结构和数据分析功能,使得数据清洗、转换、聚合和可视化等操作变得轻而易举。本文将介绍Pandas的基础应用,帮助读者快速上手并掌握其核心功能。 一…

openlayers禁用鼠标滚轮放大、拖拽事件并设置为只有按住Ctrl键才可以执行放大拖拽操作

禁用openlayers鼠标滚轮放大、拖拽移动地图设置这两行代码即可: new Map({interactions: defaults({ dragPan: false, mouseWheelZoom: false }), }) 或者设置只允许按住Ctrl键才可以操作 import { DragPan, MouseWheelZoom, defaults } from "ol/interact…

利用第三方服务对目标进行被动信息收集防止被发现(web安全白帽子)

利用第三方服务对目标进行被动信息收集防止被发现(web安全白帽子) 1 被动信息收集1.1 信息收集内容1.2 信息用途 2 信息收集-DNS2.1 DNS信息收集NSLOOKUP2.1.1 ping2.1.2 nslookup 2.2 DNS信息收集-DIG(此命令查到的结果更复杂些,…

算法训练营day19--530.二叉搜索树的最小绝对差+501.二叉搜索树中的众数+236. 二叉树的最近公共祖先

一、530.二叉搜索树的最小绝对差 题目链接:https://leetcode.cn/problems/minimum-absolute-difference-in-bst/ 文章讲解:https://programmercarl.com/0530.%E4%BA%8C%E5%8F%89%E6%90%9C%E7%B4%A2%E6%A0%91%E7%9A%84%E6%9C%80%E5%B0%8F%E7%BB%9D%E5%AF…

shell脚本中sudo密码自动输入

在shell脚本中, 我们可能需要用到sudo权限, 如果没有免密设置, 是需要输入密码的, 但是在自动化的脚本中,我们不希望进行手动密码输入,这时就需要用到密码自动输入。 方法如下: echo "my_passwd&quo…

【ubuntu noble】给 apt 添加代理

修改apt.conf sudo vi /etc/apt/apt.conf添加以下内容 Acquire::http::Proxy "http://proxy.example.com:8080"; Acquire::https::Proxy "http://proxy.example.com:8080";出现公钥问题 去我上一篇博客,有解决方案

Ext JS+Spring Boot 使用Ajax方式上传文件

实现方式 使用 Ext JS 进行 AJAX 调用以传递文件通常涉及到创建一个 FormData 对象,将文件附加到这个对象中,然后通过 Ext JS 的 AJAX API 发送这个对象。 基本步骤 以下是使用 Ext JS 发送文件的基本步骤: 准备文件和数据: 首先需要获取到要传递的文件 创建 FormData 对…

红队内网攻防渗透:内网渗透之内网对抗:横向移动篇NTLM中继Relay重放SMBEWSLADP协议强制认证钓鱼监听

NTLM Relay其实严格意义上并不能叫NTLM Relay,而是应该叫 Net-NTLM Relay。它是发生在NTLM认证的第三步,在 Type3 Response消息中存在Net-NTLM Hash,当攻击者获得了Net-NTLM Hash后,可以进行中间人攻击,重放Net-NTLM Hash,这种攻击手法也就是大家所说的NTLM Relay(NTLM 中…

MAB规范(3):Chapter6 Glossary 术语表

第6章 - 术语表 此章不做过多的批注,都是些简单的术语解释。

学分制系统 GetCalendarContentById SQL注入致RCE漏洞复现

0x01 产品简介 学分制系统由上海鹏达计算机系统开发有限公司研发,是基于对职业教育特点和需求的深入理解,结合教育部相关文件精神,并广泛吸纳专家、学者意见而开发的一款综合性管理系统。系统采用模块化的设计方法,方便学校根据自身教学改革特点、信息化建设进程情况选择、…