搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
Cpp五条
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
docker测试环境部署踩坑系列(编写中)_docker 配置文件daemon.json中需要配置参数"ip6tables": true,但结果
2
人工网络英语怎么说,人工网络英语怎么写_英语的ai网络
3
linux ip 修改处理_liunx在设置ip是,不小心把地址修改了
4
python绘制三维图_python画三维图
5
Android Studio2022年10月更新Logcat配置过滤_android studio 2022 logcat 过滤
6
HarmonyOS 安装_huawei c3安装harmonyos
7
LINUX虚拟机与主机的文件交互_vmware获取linux虚拟机文件
8
Android 4.2原生软件可精简内容详细列表_android phototable是什么软件
9
Playwright系列:第12章 使用Playwright Profiler进行性能分析与优化
10
android如何调用显示和隐藏系统默认的输入法_adnroid requesthideself
当前位置:
article
> 正文
TCP/IP协议详解_tcp/ip协议 数据格式
作者:Cpp五条 | 2024-03-10 01:59:39
赞
踩
tcp/ip协议 数据格式
认识
IP
地址
概念
IP
地址(
Internet Protocol Address
)是指互联网协议地址,又译为网际协议地址。
作用
IP
地址是
IP
协议提供的一种统一的地址格式,它为互联网上的每一个网络和每一台主机分配一个逻辑地址,以此来屏蔽物理地址的差异。
格式
IP
地址是一个
32
位的二进制数,通常被分割为
4
个
“8
位二进制数
”
(也就是
4
个字节),如:
01100100.00000100.00000101.00000110
。
通常用
“
点分十进制
”
的方式来表示,即
a.b.c.d
的形式(
a,b,c,d
都是
0~255
之间的十进制整数)。如:100.4.5.6。
组成
IP
地址分为两个部分,网络号和主机号
网络号
:
标识网段
,保证相互连接的两个网段具有不同的标识;
主机号
:
标识主机
,同一网段内,主机之间具有相同的网络号,但是必须有不同的主机号;
子网掩码
格式
子网掩码格式和
IP
地址一样,也是一个
32
位的二进制数。其中左边是网络位,用二进制数字
“1”
表示,
1的数目等于网络位的长度;右边是主机位,用二进制数字“0”
表示,
0
的数目等于主机位的长度。
子网掩码也可以使用二进制所有高位
1
相加的数值来表示
。
作用
(1)划分
A
,
B
,
C
三类
IP
地址子网:
如一个
B
类
IP
地址:
191.100.0.0
,按
A ~ E
类分类来说,网络号二进制数为
16
位网络号
+16
位主机号。
假设使用子网掩码
255.255.128.0
(即
17
) 来划分子网,意味着划分子网后,高
17
位都是网络位
/
网络 号,也就是将原来16
位主机号,划分为
1
位子网号
+15
位主机号。
此时,
IP
地址组成为:网络号
+
子网号
+
主机号,网络号和子网号统一为网络标识(划分子网后的网络
号
/
网段)
计算方式
将
IP
地址和子网掩码进行
“
按位与
”
操作(二进制相同位,与操作,两个都是
1
结果为
1
,否则为
0
),得 到的结果就是网络号。 将子网掩码二进制按位取反,再与 IP
地址位与计算,得到的就是主机号。
认识
MAC
地址
MAC
地址,即
Media Access Control Address
,用于标识网络设备的硬件物理地址。
主机具有一个或多个网卡,路由器具有两个或两个以上网卡;其中每个网卡都有唯一的一个
MAC
地址。
网络通信,即网络数据传输,本质上是网络硬件设备,将数据发送到网卡上,或从网卡接收数据。
硬件层面,只能基于
MAC
地址识别网络设备的网络物理地址。
总结
IP
地址和
MAC
地址
IP
地址描述的是
路途总体的起点和终点
;是给人使用的网络逻辑地址。
MAC
地址描述的是路途上的每一个区间的起点和终点,即
每一跳的起点和终点
;是给网络硬件设
备使用的网络物理地址。
TCP
协议
TCP
,即
Transmission Control Protocol
,传输控制协议。人如其名,要对数据的传输进行一个详细的控制。
TCP
协议段格式
源
/
目的端口号:表示数据是从哪个进程来,到哪个进程去;
32
位序号
/32
位确认号;
4
位
TCP
报头长度:表示该
TCP
头部有多少个
32
位
bit
(有多少个
4
字节);所以
TCP
头部最大长度是 15 * 4 = 60
6
位标志位
:
URG
:紧急指针是否有效
ACK
:确认号是否有效
PSH
:提示接收端应用程序立刻从
TCP
缓冲区把数据读走
RST
:对方要求重新建立连接;我们把携带
RST
标识的称为
复位报文段
SYN
:请求建立连接;我们把携带
SYN
标识的称为
同步报文段
FIN
:通知对方,本端要关闭了,我们称携带
FIN
标识的为
结束报文段
16
位窗口大小
16
位校验和:发送端填充,
CRC
校验。接收端校验不通过,则认为数据有问题。此处的检验和不
光包含
TCP
首部,也包含
TCP
数据部分。
16
位紧急指针:标识哪部分数据是紧急数据;
40
字节头部选项;
TCP
原理
TCP
对数据传输提供的管控机制,主要体现在两个方面:安全和效率。
这些机制和多线程的设计原则类似:保证数据传输安全的前提下,尽可能的提高传输效率。
确认应答机制(安全机制)
每一个
ACK
都带有对应的确认序列号,意思是告诉发送者,我已经收到了哪些数据;下一次你从哪里开始发。
超时重传机制(安全机制)
主机
A
发送数据给
B
之后,可能因为网络拥堵等原因,数据无法到达主机
B
;
如果主机
A
在一个特定时间间隔内没有收到
B
发来的确认应答,就会进行重发;
连接管理机制(安全机制)
滑动窗口(效率机制)
对每一个发送的数据段,都要给一个
ACK
确认应答。收到
ACK
后再发送 下一个数据段。这样做有一个比较大的缺点,就是性能较差。尤其是数据往返的时间较长的时候。
既然这样一发一收的方式性能较低,那么我们一次发送多条数据,就可以大大的提高性能(其实是将多个段的等待时间重叠在一起了)。
流量控制(安全机制)
接收端处理数据的速度是有限的。如果发送端发的太快,导致接收端的缓冲区被打满,这个时候如果发送端继续发送,就会造成丢包,继而引起丢包重传等等一系列连锁反应。
因此
TCP
支持根据接收端的处理能力,来决定发送端的发送速度。这个机制就叫做
流量控制(
Flow
Control
)
;
拥塞控制(安全机制)
虽然
TCP
有了滑动窗口这个大杀器,能够高效可靠的发送大量的数据。但是如果在刚开始阶段就发送大量的数据,仍然可能引发问题。
因为网络上有很多的计算机,可能当前的网络状态就已经比较拥堵。在不清楚当前网络状态下,贸然发送大量的数据,是很有可能引起雪上加霜的。
TCP
引入
慢启动
机制,先发少量的数据,探探路,摸清当前的网络拥堵状态,再决定按照多大的速度传输数据;
少量的丢包,我们仅仅是触发超时重传;大量的丢包,我们就认为网络拥塞;
当
TCP
通信开始后,网络吞吐量会逐渐上升;随着网络发生拥堵,吞吐量会立刻下降;
拥塞控制,归根结底是
TCP
协议想尽可能快的把数据传输给对方,但是又要避免给网络造成太大压力的折中方案。
延迟应答(效率机制)
如果接收数据的主机立刻返回
ACK
应答,这时候返回的窗口可能比较小。
假设接收端缓冲区为
1M
。一次收到了
500K
的数据;如果立刻应答,返回的窗口就是
500K
;
但实际上可能处理端处理的速度很快,
10ms
之内就把
500K
数据从缓冲区消费掉了;
在这种情况下,接收端处理还远没有达到自己的极限,即使窗口再放大一些,也能处理过
来;
如果接收端稍微等一会再应答,比如等待
200ms
再应答,那么这个时候返回的窗口大小就是
1M
;
捎带应答(效率机制)
在延迟应答的基础上,我们发现,很多情况下,客户端服务器在应用层也是
"
一发一收
"
的。意味着客户端给服务器说了 "How are you"
,服务器也会给客户端回一个
"Fine, thank you"
;
那么这个时候
ACK
就可以搭顺风车,和服务器回应的
"Fine
,
thank you"
一起回给客户端
如何避免粘包问题?
对于定长的包,保证每次都按固定大小读取即可;例如上面的
Request
结构,是固定大小
的,那么就从缓冲区从头开始按
sizeof
(
Request
)依次读取即可;
对于变长的包,可以在包头的位置,约定一个包总长度的字段,从而就知道了包的结束位
置;
对于变长的包,还可以在包和包之间使用明确的分隔符(应用层协议,是自己来定的,只要保证分隔符不和正文冲突即可);
UDP
协议
UDP
协议端格式
16
位
UDP
长度,表示整个数据报(
UDP
首部
+UDP
数据)的最大长度;
如果校验和出错,就会直接丢弃;
UDP
的特点
UDP
传输的过程类似于寄信。
无连接
知道对端的
IP
和端口号就直接进行传输,不需要建立连接;
不可靠
没有任何安全机制,发送端发送数据报以后,如果因为网络故障该段无法发到对方,
UDP
协议层也不会给应用层返回任何错误信息;
面向数据报
应用层交给
UDP
多长的报文,
UDP
原样发送,既不会拆分,也不会合并;
用
UDP
传输
100
个字节的数据:
如果发送端一次发送
100
个字节,那么接收端也必须一次接收
100
个字节;而不能循环接收
10
次,
每次接收
10
个字节。
缓冲区
UDP
只有接收缓冲区,没有发送缓冲区:
UDP
没有真正意义上的
发送缓冲区
。发送的数据会直接交给内核,由内核将数据传给网络层协议
进行后续的传输动作;
UDP
具有接收缓冲区,但是这个接收缓冲区不能保证收到的
UDP
报的顺序和发送
UDP
报的顺序一
致;如果缓冲区满了,再到达的
UDP
数据就会被丢弃;
UDP
的
socket
既能读,也能写,这个概念叫做
全双工
大小受限
UDP
协议首部中有一个
16
位的最大长度。也就是说一个
UDP
能传输的数据最大长度是
64K
(包含
UDP
首部)。
基于
UDP
的应用层协议
NFS
:网络文件系统
TFTP
:简单文件传输协议
DHCP
:动态主机配置协议
BOOTP
:启动协议(用于无盘设备启动)
DNS
:域名解析协议
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/Cpp五条/article/detail/216948
推荐阅读
article
如何
查看
微信
小
程序
路径
?亲测记录
_
微信
公众
号
小
程序
路径
在哪
查看
...
第一步登录
微信
公众
平台账号第二步新建图文第三步点击插入
小
程序
第四步选择
小
程序
a、如果已知appid,直接输入,并点击“下...
赞
踩
article
ARM
Cortex
-
M3
权威指南-概览和基础...
芯片设计商得到C
M3
核的授权后,就会把C
M3
用到自己的芯片中,做一些定制化的设计,所以不同的厂商有不同的配置,想了解具体...
赞
踩
article
ESP32
-
CAM
板载
摄像头
模块进行简单
的
图像
采集和网络传输。...
ESP32
-
CAM
是一款集成了 Wi-Fi 和
图像
传感器
的
开发板,它可以用于实现基于 Arduino 平台
的
物联网应用...
赞
踩
article
PythonCV
学习记录
2
——一些基本
函数
的
整理
_
python
cv
函数
用法...
目录零之前言一.图片1.读入图片①参数②返回
2
.显示图片①参数②返回③注意3.保存图片①参数②返回二.视频1.加载视频①...
赞
踩
article
MyBatis
事务
手动 提交_
mybatisplus
手动
commit
...
@AutowiredDataSourceTransactionManager transactionManager;//...
赞
踩
article
Jenkins
自动
构建部署
项目
到远程
服务器
上...
1.下载jenkins下载地址:https://jenkins.io/启动jenkins方式有2种1.1切换到jenki...
赞
踩
article
jenkins
_
docker
安装
jenkins
...
这里笔者使用的是该镜像的1.24.1-bcc31d32159f这个版本,这个镜像的
jenkins
是2.2版本的,只不过镜...
赞
踩
article
基于
soapui
的
webservice
模拟
方法_
模拟
webservice
接口
...
客户端和服务端进行测试,如下图,请求界面,路径设置与服务端路径一致,点击请求按钮,服务端返回响应参数,如下图。创建成功,...
赞
踩
article
rustdesk
-
server
的
中继
服务器
的
是
什么
原理?_
rustdesk
中继
服务器
有
什么
用...
在这种情况下,使用一个
中继
服务器
可以简化连接过程,并提供更可靠和安全
的
连接。RustDes确实可以直接连接两个不同局域网...
赞
踩
article
【惊喜福利】
Docker
容器
化
部署
nextcloud
网盘
,
享受高速稳定的
文件共享
体验!_nextcl...
NextCloud的客户端覆盖了各种平台
,
包括Windows、Mac、Android、iOS、Linux等
,
也提供了网页...
赞
踩
article
nginx
一键
部署
shell
脚本
_
部署
nginx
的
shell
脚本
...
nginx
一键
部署
shell
脚本
一键
部署
nginx
一键
部署
nginx
#/bin/bashsystemctl stop f...
赞
踩
article
Neovim
Lua
配置
从0到1_
neovim
lua
配置
...
CygwinMSYS2来源于Cyguns的Cygwin,最初Cyguns的一位程师发现Windows系统使用COFF作为...
赞
踩
article
Mybatis
的
事务
控制_
mybatis
事务
控制...
事务
:访问并可能更新数据库中各种数据项的一个程序执行单元(unit)
事务
的四个特性:原子性、一致性、隔离性、持久性不考虑...
赞
踩
article
Pytorch
线性
回归
实现
(原理)...
直接在tensor中设置 requires_grad=True,每次操作这个数的时候,就会保存每一步的数据。也就是保存了...
赞
踩
article
Python
cv
模块
实际应用_
cv
模块
功能
python
...
Python
cv
模块
实际应用_
cv
模块
功能
python
cv
模块
功能
python
主要列出一些c...
赞
踩
article
Jenkins
结合.
net
平台综合应用之
使用
FileZilla
搭建
ftp
服务器
...
上一节我们讲解了如何编译web项目,web项生成以后我们是手动复制到iis目录下的,这显然不符合devops初衷,这里我...
赞
踩
article
ubuntu
设置
允许
root
远程
登录
_
ubuntu
允许
root
远程
登录
...
在打开sshd_config后,找到PermitRootLogin without-password 修改为Permit...
赞
踩
article
使用U盘
安装
银河
麒麟
服务器
操作系统
V10SP2
出现“
设置
基础
软件
仓库时出错”报错导致无法继续
安装
的解...
使用U盘
安装
银河
麒麟
服务器
操作系统
V10SP2
出现“
设置
基础
软件
仓库时出错”报错导致无法继续
安装
的解决方法_
设置
基础
软件
...
赞
踩
article
VUE高频面试题_
vite
打包
减少
请求
数量
提升
加载
速度
...
常见的八股文,面试的时候很有用_
vite
打包
减少
请求
数量
提升
加载
速度
vite
打包
减少
请求
数量
提升
加载
速度
...
赞
踩
article
浏览器
上
登录
堡垒
机
_达晨
Family
|
堡垒
机
哲学史齐治科技
产品
经理的深度思考...
一、缘起:
堡垒
机
从哪里来?——无风不起浪,从需求中来2005年,中国,我在某互联网公司的安全部门,面临3个问题。1. 运...
赞
踩
相关标签
微信小程序路径
小程序路径
微信小程序
小程序
微信
arm开发
网络
人工智能
mybatis
事务
commit
手动
提交
jenkins
自动部署项目
docker
运维
服务器
servlet
java
程序人生
linux
nginx
centos