IP协议及相关技术协议

一、IP基本认识

1. IP的作用

IP在TCP/IP模型中处于网络层,网络层的主要作用是实现主机与主机之间的通信,而IP的作用是在复杂的网络环境中将数据包发送给最终目的主机。

2. IP与MAC的关系

简单而言,MAC的作用是实现“直连”的两个设备之通信,而IP负责“没有直连”的两个网络之间进行通信传输。

16e6f4fe9335625fa4513a61b83025c4.png

源IP和目的IP在传输过程中不会改变,只有源MAC和目的MAC在一直变化。

二、IP地址的基础知识

1. IP地址的分类

IP地址总共分为A、B、C、D、E五类。

eb1d4083a7cb3a251a9d8280c9e92e69.png

每类地址中,除去主机号全为1(广播地址)和全为0(用于指定某个网络)的,能够包含的最大主机数量是可以推算的,比如C类:2^8-2 = 254。

广播的分类

本地广播:发送给192.168.0.255的包不会到达192.168.1.0/24的网络

直接广播:从192.168.0.0网络下的主机发包到192.168.1.255(通常会被路由器认为不安全而屏蔽,无法穿透路由)

多播(组播)地址的作用:

不同于单播(单独发包)、广播(无法穿透路由,不转发广播包),多播用于将同样的包发送给特定组内的所有主机(可穿透路由)。

从224.0.0.0 ~ 239.255.255.255都是多播可用的范围,划分为三类:

        · 224.0.0.0 ~ 224.0.0.255为预留的多播地址,只能在局域网中,路由器不进行转发。

        · 224.0.1.0 ~ 238.255.255.255为用户可用的多播地址,可用用于Internet上。

        · 239.0.0.0 ~ 239.255.255.255为本地管理的多播地址,可供内部网在内部使用,仅在本地范围内有效。

IP分类的优缺点

优点

通过看前几位就可以找出网络号和主机号(A类0,B类10,C类110,D类1110,E类1111)。

缺点

(1)同一网络下没有地址层次,比如一个公司用B类地址,可能需要根据生产环境、测试环境、开发环境来划分地址层次,而这种IP分类是没有地址层次划分功能的。

(2)不能很好与现实网络匹配,C类254太少,B类65534又可能太多。

这两个缺点,都可以在CIDR无分类地址解决。

2. 无分类地址CIDR、子网掩码
无分类地址CIDR

a.b.c.d/x,其中 /x 表示前 x 位属于网络号,后面的就是主机号。比如10.100.122.2/24。

子网掩码

掩码掩盖掉主机号,剩余的就是网络号,将子网掩码与IP地址按位进行AND运算,就可以得到网络号。

为什么要分离网络号和主机号

在两台计算机通信时,首先判断是否处于同一个广播域内(网络号是否相同),如果是,就可以直接把数据包发送到目的主机。路由器寻址时,也是通过这样的方式来把数据包转发到对应的网络内。

子网划分

子网掩码除了划分出网络号、主机号,还可以划分子网——把主机地址分为子网网络地址、子网主机地址。如下,划分出四个子网。

3. 公有IP地址、私有IP地址

私有IP地址范围由IANA互联网编号分配局规定。

f4617868410bf1a815268a762ca7ae93.png

4. IP地址与路由控制
路由控制表

IP中网络号是用于进行路由控制的。主机、路由器中的路由控制表记录着网络号与下一步应该发送至的路由器地址。

本地回环

127.0.0.1作为本地回环地址(localhost),使用时,数据包不会流向网络。

5. IP分片与重组

每种数据链路的最大传输单元都是不同的,如以太网的MTU是1500字节。

当IP数据包大于MTU时,就会被分片,而重组只能由主机完成

在分片传输中,一旦某个分片丢失,则会造成整个IP数据报作废。TCP引入了MSS在TCP层进行分片,不由IP层分片。而对于UDP,尽量不要发送大于一个MTU的数据报文。

6. IPv6

IPv4是32位的大约可以提供42亿个地址,而IPv6是128位的,可分配地址的数量是很大的。此外IPv6还有更好的安全性和扩展性。

不过IPv4和IPv6之间互不兼容,不但需要设备支持,网络运营商也需要对现有设备升级,所以IPv6普及比较慢。

亮点

(1)即使没有DHCP服务器也可自动配置

(2)头部长度采用固定值40字节,去掉了报头校验和,简化了头部结构,提高了传输的性能

(3)对伪造IP地址有网络安全功能,能够防止线路窃听,安全性提升

IPv6地址的标识方法

16位为一组,用“:”隔开,连续的零可以省略,用“::”隔开。不过,一个IP地址中只能出现一次“::”。

d9bd73aecef80f581eb43168178b8b22.png

单播地址类型

(1)链路本地单播地址:同一链路单播通信,不经过路由器。

(2)唯一本地地址:在内网里单播通信,相当于IPv4的私有IP。

(3)全局单播地址:在互联网通信,相当于IPv4的公有IP。

b79684c1b9cf7e80160388e11071eba3.png

7. IPv4头部、IPv6头部

fd3baca4e8f1c5f7aa88ad7f9ed2e00e.png

IPv6相比IPv4头部的改进:

(1)取消了首部校验和字段。因为在数据链路层、传输层都会校验,IPv6取消了IP的校验。

(2)取消了分片/重组相关字段

(3)取消可选字段。这部分的内容出现在,“下一个首部”这个字段。

三、IP协议相关技术

1. DNS域名解析

把网址www.server.com解析为对应的IP地址,这就是DNS域名解析。域名使用句点来分隔,越右位置层级越高,DNS是一个应用层协议(根域、顶级域、权威域)

f1ea1363fd241f4d2dc021bcd232e46c.png

客户端发出DNS请求后

浏览器查看自己的缓存->请求操作系统的缓存->查询本机域名解析文件hosts->访问本地DNS服务器->根域名服务器->.com顶级域DNS服务器->server.com权威域DNS服务器

DNS使用什么传输层协议

域名解析通过UDP协议通信,有最大限制512字节,不过查寻域名所发送的数据一般不会超过。

在区域传送(从主DNS复制一部分到区域DNS)时,使用的是有重传机制保障的TCP协议。

2. ARP与RARP协议

ARP协议(数据链路层)

主机的路由表可用找到下一跳的IP地址,ARP协议,通过广播ARP请求获得ARP响应,可以求得下一跳的MAC地址。操作系统通常会缓存这个MAC地址一定时间,以便近期重复使用。

07e71955d355d9799db3734991f70c5d.png

RARP协议(数据链路层)

RARP协议用于已知MAC地址求IP地址。这个过程通常需要一台RARP服务器。主机发送RARP请求包,从服务器拿到RARP响应来得知自己的IP地址(一般也是广播)。

977c10bf5a630e57757e97a65b77dc9c.png

3. DHCP动态获取IP地址

分配流程:

747675915c3bf98291bbd775cfdcd4eb.png

四个步骤:

(1)客户端通过UDP广播(不知道DHCP服务器位置)DHCP发现报文(DHCP DISCOVER)的IP数据段,源端口68,目的端口67。

(2)DHCP服务器通过DHCP提供报文(DHCP OFFER)向客户端做出响应,内容包括IP地址、子网掩码、默认网关、DNS服务器、地址租期。

(3)客户端收到一个或多个服务器的OFFER后,选择一个服务器,给它发送DHCP请求报文(DHCP REQUEST),回显配置的参数。

(4)服务端用DHCP ACK报文响应。

IP租约处理:

当DHCP IP地址快到期后,客户端会向服务器发送DHCP请求报文

(1)如果服务器同意继续使用,则用DHCP ACK应答,客户端延长租期;

(2)如果不让继续,则DHCP NACK,客户端就要停用这个IP。

DHCP中继代理:

在DHCP交互过程中,全程都是UDP广播通信,广播不能穿透路由器,那么每个网络都需要一个DHCP服务器吗?

DHCP中继代理,解决了这个问题,使不同网段的IP地址分配也能由一个DHCP服务器统一管理

9d9f68efd5740d14dd456757b6575ebb.png

4. NAT(私有公有IP)与NAPT网络地址与端口转换

NAT协议:

IPv4的地址有限,通过CIDR无分类地址可以减缓IPv4的消耗速度。而NAT网络地址转换的方法,也缓解了这个问题。

简单而言,NAT就是把私有IP转换为公有IP。而普通的NAT转换并不会减少IPv4地址的消耗。

NAPT协议:

NAPT网络地址与端口转换,这个转换是IP地址+端口号一同转换的,可以减少消耗。

679ee150f758a1c944b78a601fa3864e.png

这种转换在TCP连接首次握手SYN时就会由NAT路由器生成转换表,关闭连接FIN的ACK时会被删除。

所存在的问题:

因为NAT/NAPT都依赖于自己的转换表,会有以下问题:

(1)外部无法主动与NAT内部服务器建立连接,因为NAPT转换表没有转换记录;

(2)转换的过程有性能开销;

(3)如果NAT路由器重启,所有的TCP连接都会重置。

两种解决方法:

(1)改用IPv6

(2)NAT穿透技术

客户端主动从NAT设备获取公有IP地址,然后自己建立端口映射条目,然后用这个条目对外通信,就不需要NAT设备来进行转换了。

5. ICMP控制报文协议

Internet Control Message Protocol,主要功能包括:1. 确定IP包是否成功送达,2. 报告发送过程中IP包被废弃的原因,3. 改善网络设置 等。相关的通知消息也是使用IP进行发送

4551af316540bc8bc962b52ab1716a29.png

ICMP大致分为两类:

d9371182431d6d46f1882959444ed898.png

6. IGMP组管理协议

这个协议和多播(组播)有关,是用来管理组的。IGMP工作在主机和最后一跳之间

6093578dbfcd243905187a530587ef0d.png

IGMP报文向路由器申请加入/退出组播组,主机申请加入到组播组时,路由器就会记录IGMP路由器表,路由器后续就会转发组播包到对应的主机了。
IGMP报文采用IP封装,IP头部的协议号为2,而且TTL字段值通常为1,因为IGMP是工作在主机与连接的路由器之间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WISHMELUCK1'

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值