网络原理-IP/数据链路层协议

简介: 网络原理-IP/数据链路层协议

一. IP

IP协议有两个版本,IPv4和IPv6.我们通常所用的IP协议,若没有特殊说明,默认都是IPv4.


IPv4数量=2^32,大约43亿左右,而TCP/IP协议规定,每个主机都需要有一个IP地址.对于全世界的计算机来说,这个数量是不够的,所以后来推出了IPv6(长度128位,是IPv4的4倍).但因为目前IPv4还广泛的使用,且可以使用其他技术(NAT机制)来解决IP地址不足的问题,所以IPv6也就没有普及.


1.1 NAT机制

NAT机制把所有的IP地址分成两大类.

内网IP: 10.* , 172.16*-172.31* , 192.168*(可以重复出现,尤其是在不同的局域网)

外网IP: 剩下的IP(必须是惟一的)

NAT机制可以用买快递来解释:在淘宝上买衣服,收货地址:郑州市,金水区,龙子湖~.但是龙子湖的人数以万计,龙子湖这个地址是唯一的,但是代表的人不一定唯一.因此内网设备如果要访问外网,会给他分配一个外网IP,但是这个外网IP不是这个设备独占的,而是这个内网中所有的设备都共用这一个外网IP.

若此时有多个主机通过路由器发送数据报,路由器返回数据报时是如何区分不同的主机呢?

在主机发送数据报的时候,数据报中含有端口号,路由器在替换源IP和端口号时,会记住所替换的端口号和源IP,在返回数据报时,就能准确区分哪个数据报属于哪个主机


1.2 IP地址的组成

IP地址分为两个部分,网络号和主机号

• 网络号: 标识一个局域网,保证相互连接的两个网段具有不同的标识,

• 主机号: 标识局域网内部的主机,同一网段内,主机之间具有相同的网络号,但是必须有不同的主机号,

从上图可以看出,一个路由器中,有两个IP地址,分别是在不同的局域网中,一个路由器的作用就是把两个局域网连接起来

1.3 子网掩码

1.4 特殊的IP地址

主机号为0的ip. 192.168.0.0, 就是网络号,局域网里不应该存在某个主机,主机号为0.


主机号为全1, 192.168.0.255, 广播地址,往这个地址上发送udp数据报,此时这个数据报就会被转发给整个局域网中的所有主机.(TCP不支持广播)


手机投屏时就是利用了广播地址,要想把手机上的视频投放到电视上来看,投屏软件要求你的手机和电视,在同一个局域网中,此时,你的手机就有一个自动查找电视的过程,手机往局域网的广播地址上发送个数据报,看哪个ip有回应,电视上也有对应的投屏软件,收到了数据报就回应了,因此你的手机就知道电视的ip了.


主机号为1,192.168.0.1,一般作为"网关ip" ,"网关"可以理解为局域网的出入口.

二. 以太网数据帧

认识MTU

MTU相当于发快递时对包裹尺寸的限制,这个限制是不同的数据链路对应的物理层,因为不同的数据链路层协议,MTU不一样,只有以太网才是1500.


• 以太网中帧中的数据长度规定最小46字节,最大是1500字节,ARP数据包的长度不够46字节,要在后面补填充位


• 最大值1500成为以太网的最大传输单元(MTU),不同的网络类型有不同的MTU;


• 如果一个数据报从以太网路由到拨号链路上,数据包长度大于拨号链路的MTU了,则需要对数据包进行分片;

MTU 对IP协议的影响


由于数据链路层MTU的限制,对于较大的数据包要进行分包.


• 将较大的IP包分成多个小包,并给每个小包打上标签


• 每个小包IP协议头的16为标识都是相同的


• 每个小包的IP协议头的3位标志字段中,第2位置为0,表示允许分片,第3位来表示结束标记(当前是否是最后一个小包,是的话置为1,否则置为0);


• 到达对端是再将这些小包,按顺序重组,拼装到一起返回给传输层


• 一旦这些小包中任意一个丢失,接收端就会重组失败,但是IP层不会负责重新传输数据

虽然IP能拆包,仍然不能改变UDP最大长度是64k这样的现实,由于拆出的这些IP数据报中只有一份UDP首部,但是对UDP的限制还是存在的.

相关文章
|
7月前
|
机器学习/深度学习 PyTorch TensorFlow
卷积神经网络深度解析:从基础原理到实战应用的完整指南
蒋星熠Jaxonic,深度学习探索者。深耕TensorFlow与PyTorch,分享框架对比、性能优化与实战经验,助力技术进阶。
|
7月前
|
监控 负载均衡 安全
WebSocket网络编程深度实践:从协议原理到生产级应用
蒋星熠Jaxonic,技术宇宙中的星际旅人,以代码为舟、算法为帆,探索实时通信的无限可能。本文深入解析WebSocket协议原理、工程实践与架构设计,涵盖握手机制、心跳保活、集群部署、安全防护等核心内容,结合代码示例与架构图,助你构建稳定高效的实时应用,在二进制星河中谱写极客诗篇。
WebSocket网络编程深度实践:从协议原理到生产级应用
|
7月前
|
网络协议 Linux 虚拟化
配置VM网络:如何设定静态IP以访问主机IP和互联网
以上就是设定虚拟机网络和静态IP地址的基本步骤。需要注意的是,这些步骤可能会因为虚拟机软件、操作系统以及网络环境的不同而有所差异。在进行设定时,应根据具体情况进行调整。
560 10
|
8月前
|
机器学习/深度学习 人工智能 算法
卷积神经网络深度解析:从基础原理到实战应用的完整指南
蒋星熠Jaxonic带你深入卷积神经网络(CNN)核心技术,从生物启发到数学原理,详解ResNet、注意力机制与模型优化,探索视觉智能的演进之路。
745 11
|
8月前
|
运维 架构师 安全
二层协议透明传输:让跨域二层协议“无感穿越”多服务商网络
简介:本文详解二层协议透明传输技术,适用于企业网工、运营商及架构师,解决LLDP/LACP/BPDU跨运营商传输难题,实现端到端协议透传,提升网络韧性与运维效率。
|
8月前
|
安全 测试技术 虚拟化
VMware-三种网络模式原理
本文介绍了虚拟机三种常见网络模式(桥接模式、NAT模式、仅主机模式)的工作原理与适用场景。桥接模式让虚拟机如同独立设备接入局域网;NAT模式共享主机IP,适合大多数WiFi环境;仅主机模式则构建封闭的内部网络,适用于测试环境。内容简明易懂,便于理解不同模式的优缺点与应用场景。
1185 0
|
SQL 安全 网络安全
网络安全与信息安全:知识分享####
【10月更文挑战第21天】 随着数字化时代的快速发展,网络安全和信息安全已成为个人和企业不可忽视的关键问题。本文将探讨网络安全漏洞、加密技术以及安全意识的重要性,并提供一些实用的建议,帮助读者提高自身的网络安全防护能力。 ####
461 17
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将从网络安全漏洞、加密技术和安全意识三个方面进行探讨,旨在提高读者对网络安全的认识和防范能力。通过分析常见的网络安全漏洞,介绍加密技术的基本原理和应用,以及强调安全意识的重要性,帮助读者更好地保护自己的网络信息安全。
352 10
|
存储 SQL 安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将介绍网络安全的重要性,分析常见的网络安全漏洞及其危害,探讨加密技术在保障网络安全中的作用,并强调提高安全意识的必要性。通过本文的学习,读者将了解网络安全的基本概念和应对策略,提升个人和组织的网络安全防护能力。