A 类 0.0.0.0 到 127.255.255.255
B 类 128.0.0.0 到 191.255.255.255
C 类 192.0.0.0 到 223.255.255.255
D 类 224.0.0.0 到 239.255.255.255
E 类 240.0.0.0 到 247.255.255.255
大家很显然发现不同的类别后序由于网络号和主机号长度问题可以划分的种类差别非常大,所以大部分都是申请了B类,这也导致B 类地址很快就分配完了, 而 A 类却浪费了大量地址
因此这种方案被抛弃,出现了一种新的方案:
CIDR:
该方案是如何实现网段划分的呢??
该方案通过引入一个额外的子网掩码(subnet mask)来区分网络号和主机号,子网掩码也是一个 32 位的正整数. 通常用一串 "0" 来结尾,将 IP 地址和子网掩码进行 "按位与" 操作, 得到的结果就是网络号,网络号和主机号的划分与这个 IP 地址是 A 类、 B 类还是 C 类无关;
可见,IP 地址与子网掩码做与运算可以得到网络号, 主机号从全 0 到全 1 就是子网的地址范围
二.IP协议扩展
将IP地址中主机部分全部设置为0,就是一个网络号,这可以表示一个局域网
将IP地址中主机部分全部设置为1,就是一个广播地址,用于给同一个链路中相互连接的所有主机发送数据包
127.*的 IP 地址用于本机环回(loop back)测试,通常是 127.0.0.1
我们知道IP地址是存在数量限制的,现在我们来仔细计算下IP的大小:IP是4字节32比特位大小,即2^32次方,大约43亿左右,由于每台主机都需要一个IP地址,这表明我们大约只有43亿左右的主机可以接入网络,对于全球70亿以上来说是远远不够的,所以我们需要想到一定的解决方案,实际上我们确实有接剧情方案:
1.动态分配 IP 地址: 只给接入网络的设备分配 IP 地址. 因此同一个 MAC 地址的设备, 每次接入互联网中, 得到的 IP 地址不一定是相同的;
配置两个 IP 地址, 一个是 WAN 口 IP, 一个是 LAN 口 IP(子网IP)
LAN 口连接的主机, 都从属于当前这个路由器的子网中
路由器 LAN 口连接的主机, 都从属于当前这个路由器的子网中
不同的路由器, 子网 IP 其实都是一样的(通常都是 192.168.1.1). 子网内的主机IP 地址不能重复. 但是子网之间的 IP 地址就可以重复了 如下图:
子网内的主机需要和外网进行通信时, 路由器将 IP 首部中的 IP 地址进行替换(替换成 WAN 口 IP), 而WANip一定不同,这样逐级替换, 最终数据包中的 IP 地址成为一个公网 IP. 这种
技术称为 NAT(Network Address Translation, 网络地址转换),这也是解决上述问题的方案:即通过IP替换来解决不同局域网IP相同情况