当前位置: 首页 > article >正文

网络原理 IP协议与以太网协议

 博主主页: 码农派大星.

    数据结构专栏:Java数据结构

 数据库专栏:MySQL数据库

JavaEE专栏:JavaEE

关注博主带你了解更多数据结构知识

目录

1.网络层   IP协议

1.IP协议格式

2.地址管理

2.1 IP地址

2.2 解决IP地址不够用的问题

2.3NAT网络地址转换

2.4网段划分

 3.路由选择

2.数据链路层 以太网协议

1 认识以太⽹

2.认识MAC地址

3.ARP协议 

4.以太⽹帧格式

3.应⽤层协议DNS(DomainNameSystem)


1.网络层   IP协议

1.地址管理 => IP地址

2.路由管理 => 数据报传输路径进行规划

1.IP协议格式

4位版本号:指定IP协议的版本,对于IPv4来说,就是4,IPv6,就是6.

4位头部⻓度(header length):IP头部的⻓度是多少个32bit,也就是length*4的字节数.4bit表⽰最 ⼤的数字是15,因此IP头部最⼤⻓度是60字节.

8位服务类型(TypeOfService):3位优先权字段(已经弃⽤),4位TOS字段,和1位保留字段(必须置为 0).4位TOS分别表⽰:最⼩延时,最⼤吞吐量,最⾼可靠性,最⼩成本.这四者相互冲突,只能选择⼀个. 对于ssh/telnet这样的应⽤程序,最⼩延时⽐较重要;对于ftp这样的程序,最⼤吞吐量⽐较重要.

16位总⻓度(total length):IP数据报整体占多少个字节.

IP协议内置了拆包组包机制,单个IP数据报确实没法超过64KB,但不代表IP协议不能传输超过64KB的数据,IP协议会自动把大的数据报,拆成多个IP数据报携带传输,在接收方再进行拼装.

16位标识(id) : 同一个载荷的数据,被分成多份,交给多个IP数据报来携带,多个IP数据报,16标识(id)是相同的数值

3位标志位 : 只有2个有效,其中一个,表示这个包是否需要组包(是否拆包的一部分),另一个表示当前包是否组包的最后一个单位

13位片偏移: 决定组包的时候数据报的位置

8位⽣存时间(TimeToLive,TTL): 一个数据报在网络中最多存活多长时间. 

8位协议 : IP数据报中,携带的载荷,是哪种传输层协议的数据报

16位头部校验和: 验证数据在传输中是否出错(只是针对首部,IP报头),载荷部分TCP/UDP都有自己的校验和了

32位源地址和32位⽬标地址:表⽰发送端和接收端

IP地址是32位的整数,是一个很大的数字,不方便理解和阅读,于是就通过点分十进制把32位(4字节)通过3个圆点分割开,每一个部分是一个字节(范围是0-255)

2.地址管理

2.1 IP地址

IP地址是一个32位的整数,即42亿9千万。地址描述的是一台联网设备在网络上所占的位置,理论上来说,是不应该重复的,但现在移动互联网的时代看来是不够用的。

2.2 解决IP地址不够用的问题

1.动态分配IP地址

一个设备上网就分配IP,不上网就不分配IP

2.NAT网络地址转换

3.IPv6 使用128位(2^{128})16个字节表示IP地址  而IPv4使用32位(2^{32})4个字节

2.3NAT网络地址转换

把IP地址分为两大类:

1, 内网IP/私网IP   是以10.、172.16.-172.31.、192.168.

2,外网IP/公网IP

公网IP必须是唯一的,但私网IP是允许重复的(在不同的局域网中时允许重复的)

同一个局域网内,主机A访问主机B,不会涉及到NAT机制,公网上的设备A,访问公网上的设备B,也不会涉及到NAT机制,但如果一个局域网中的主机A访问另一个局域网的主机B,NAT机制中,不允许的!! 

如果局域网内部的设备A访问公网上的设备B ,NAT机制主要就是针对这个情况进行生效

NAT机制的缺点: 网络环境太复杂,替换过程中,每一层路由器都需要维护映射关系,每次转发数据,都要查询映射关系,都是开销

2.4网段划分

把一个IP地址会划分成2部分:网络号(标识一个局域网)+主机号(标识局域网中的设备)
同一个局域网中,网络号必须相同,主机号不同。

以我的主机为例:子网掩码为11111111 1111111 11111110 0000000,被标记为1的位置就是网络号,标记为0为主机号,那么网络号就是10.81.33,主机号为:.105

上面带有的子网掩码的划分是当下的网络环境,也有一些其他划分方式。

 3.路由选择

在网络中进行路由转发的时候,每一个路由器无法知道网络的全貌,只知道一些局部信息,这就意味IP数据转发的过程中,是探索式,启发式的。
一个网络层的数据报报每次到达一个路由器的时,会进行一个类似“问路”的过程,每一个路由器内部都有一个数据结构“路右边”,根据数据报中的目的IP查找路由表,如果查到了,就直接去对应的位置,如果没有查到路由表中会有一个默认的表项,就向默认表项转发。

2.数据链路层 以太网协议

1 认识以太⽹

"以太⽹"不是⼀种具体的⽹络,⽽是⼀种技术标准;既包含了数据链路层的内容,也包含了⼀些物理 层的内容,以太⽹是当前应⽤最⼴泛的局域⽹技术

2.认识MAC地址

MAC地址⽤来识别数据链路层中相连的节点,⻓度为48位,及6个字节.⼀般⽤16进制数字加上冒号的形式来表⽰(例如:08:00:27:03:fb:19),在⽹卡出⼚时就确定了,不能修改.mac地址通常是唯⼀的

MAC地址与IP地址区别:

1).MAC地址使用6个字节表示,IP地址使用4个,空间范围比IP地址大了60000多倍,MAC地址可以给每个设备,都分配一个唯一的MAC地址值,一般一个网卡,在出厂的时候,MAC地址就被分配好了,就写死了,MAC地址也可以作为设备身份的标识

2)MAC地址使用在数据链路层,用来实现两个相邻设备之间的数据转发(微观),IP地址使用在网络层,立足于整个转发流程,进行路径规划(宏观)

IP地址立足于全局,完成整个传输过程,而mac地址只是相邻设备的通信

3.ARP协议 

ARP不是⼀个单纯的数据链路层的协议,⽽是⼀个介于数 据链路层和⽹络层之间的协议;

ARP协议/ARP数据报建⽴了主机IP地址和MAC地址的映射关系.

4.以太⽹帧格式

IP地址立足于全局,完成整个传输过程,而mac地址只是相邻设备的通信。 

3.应⽤层协议DNS(DomainNameSystem)

即域名解析系统

域名=>网址

域名代表了IP地址

域名和IP地址,存在对应关系,一般是一个域名对应一个或者多个IP,也可能多个域名对应一个IP

把域名转换成IP地址的系统叫域名解析系统

全球搭建了DNS服务器,在全球范围里,DNS服务器数量太少,所以全球部署了许多DNS的镜像服务器供全球用户使用,每个人上网都会就近选择镜像DNS服务器.


http://www.kler.cn/news/305969.html

相关文章:

  • 匹配行最大值替换为最小值公式
  • 反射是一个新的AI模型,可以在一台性能良好的笔记本上运行并在测试中击败GPT-4o
  • matlab while (~feof(fid))语句解释
  • 【C++11】智能指针
  • AMD FSR 4已秘密开发1年 支持AI帧生成
  • opencv之图像梯度
  • Android实现关机和重启功能
  • Linux开发讲课43---/proc/net/dev文件内容详解
  • springboot-创建连接池
  • 【第36章】Spring Cloud之Seata分布式事务
  • GNU力量注入Windows:打造高效跨平台开发新纪元
  • linux上用yolov8训练自己的数据集(pycharm远程连接服务器)
  • C#中的Date Time类
  • java构造器
  • Mysql 面试题总结
  • 51. 数组中的逆序对
  • 使用 Spring Boot + Vue + ElementUI 构建简易评分系统
  • 信息安全工程师(3)TCP/IP协议簇
  • 软件测试工程师面试整理-测试生命周期
  • gingivitis
  • CSS3中的@media查询
  • HTML5超酷炫的水果蔬菜在线商城网站源码系列模板1
  • 如何调试本地npm package
  • MySQL之表的约束
  • 基于springboot的校企招聘管理系统的设计与实现
  • HTTPS的加密流程:保护你的数据传输
  • 关于决策树的一些介绍(二)
  • 物联网之Arduino编程语言
  • 【stm32笔记】使用rtt-studio与stm32CubeMx联合创建项目
  • 鸿蒙 ArkUI组件一