网络协议——IP「建议收藏」

网络协议——IP

大家好,又见面了,我是全栈君。

IPv4地址

不论什么网络设备能够经过一个网络接口卡(NIC)接入网,假定该设备要能够访问的其它设备,然后该卡必须有一个唯一的地址。候接入多个网络,相应地该设备就有多个地址。假设这个设备是主机的话。一般被称为multihomed主机。

路由器一般有多个网卡并接入多个网络,所以路由器也有多个地址,可是一般不把路由器称为multihomed主机。

IPv4使用一个32位二进制地址,所以理论上可供使用的IPv4地址一共由4 294 967 296个,即

232
。为了便于管理和寻址(路由),一个IPv4地址的32位被划分为两部分:网络ID和主机ID。

从左边開始的、连续的若干个二进制位作为网络ID,用于标识设备所在的网络;剩余的二进制位作为主机ID,用于标识在网络中的设备。

眼下有三种划分方法:分类法、子网化和CIDR。

分类法

基本划分

分类法是最早的、也是最简单的一种划分方法。它把IPv4地址固定地分为五类:A、B、C、D和E。

A类把前8位划分为网络ID。但第1位必须是0;
B类把前16位划分为网络ID,但前2位必须是10;
C类把前24位划分为网络ID。但前3位必须是110。
D类用于组播,但前4为必须是1110;
E类作为预留地址,可是前4位必须是1111。

分类法的五类地址取值范围:

取指范围
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~255.255.255.255

从表中能够看出,从A到E的取指范围是连续的。即从A类的第一个地址0.0.0.0開始到E类的最后一个地址255.255.255.255。中间没有不论什么的间断。

分类法的特点就是能够非常easy而且非常高速地确定随意一个IPv4地址的分类。由于最多仅仅须要检查其开头4位就能确定下来了。

特殊地址

  • 网络地址
    当一个IP地址中的主机ID的二进制位全为0时,该地址用来表示其网络ID所表示的网络。如192.168.1.0就表示网络ID为192.168.1的这个网络。

  • 广播地址
    当一个IP地址中的主机ID的二进制位全为1时,该地址用来表示其网络ID所表示的网络的广播地址。如192.168.1.255。这是一个C类地址,其用于表示网络ID为192.168.1.0这个网络的广播地址。

  • 当前网络的主机地址
    当一个IPv4地址中的网络ID的二进制位全为0时,该地址用来表示在当前网络、其主机ID所表示的主机。如0.0.0.123这个地址。表示的就是当前网络的主机ID为123的主机。

  • 通配地址0.0.0.0
    用来表示本机的随意一个IP地址。

    在winsock2.h头文件中面,INADDR_ANY就定义为0x00000000,即0.0.0.0。

  • 环回地址
    在A类地址中,从127.0.0.0~127.255.255.255的全部地址被称为环回地址。顾名思义,环回就是自己发给自己,即全部发送到该地址范围的数据都是发送被本机。
    一般来说,我们都使用127.0.0.1作为环回地址。而且其名字一般叫做localhost。在winsock2.h头文件中面。INADDR_LOOPBACK被定义为0x7f000001,即127.0.0.1。

  • 私有地址
    不被公网所认可的特殊的IP地址。

    • 10.0.0.0~10.255.255.255(A类)
    • 172.16.0.0~172.31.255.255(B类)
    • 192.168.0.0~192.168.255.255(C类)
      除此之外,另一个地址范围169.251.0.0~169.254.255.255,是在主机自己主动私有地址分配(APIPA)时使用的。在没有DHCPserver的网络环境下,各个主机能够使用APIPA来自己主动分给地址,使得它们之间仍然能够通信。
  • 保留地址

    • 0.0.0.0~0.255.255.255
    • 128.0.0.0~128.0.255.255
    • 191.255.0.0~191.255.255.255
    • 192.0.0.0~192.0.0.255
    • 223.255.255.0~223.255.255.255
      0.0.0.0虽然是通配地址,但事实上它也是一个保留地址。虽然我们能够在程序里面使用它,可是不能把它作为IP地址来分配给一台主机。

分类法的优缺点

长处:地址本身包括了类别信息,并不须要额外的信息来确定一个地址的网络ID和主机ID。

缺点:没有考虑到一个机构里面可能存在多个子网络的问题。

子网化

在原有三类网络A、B和C的基础上。对其进行再划分,细分出能够石瑛各种网络规模的子网(Subnet)。

详细的说。就是在A、B和C类地址的基础上,对其主机ID部分再划分。即使用主机ID的前若干位作为子网ID。剩余的位作为在该子网里的主机ID。

子网掩码

子网掩码把其相应于IPv4地址中网络ID和子网ID的部分全部位设为1,其余设为0。

目的是当把IPv4地址和子网掩码进行与操作时,其结果就是该IPv4地址的完整网络地址。

能够依据网络的须要来设置子网ID的位数。

子网ID的位数越多,则支持的子网个数就越多,同一时候每一个子网可容纳的主机个数就越少。详细的说,假定原来在分类法的方案下,主机ID位数为N(24、16、8,分别相应于A、B、C类),假设我们选择前M(M>=0 && M<N)位作为子网ID。则支持的子网个数为

2M
,每一个子网所支持的主机个数为

2NM

可变长度子网掩码

可变长度子网掩码指的是我们在选择子网ID位数的时候。并不须要使全部划分出来的子网都具有同样位数的子网ID,而是能够依据须要,对不同的子网指定不同位数的子网ID。

无分类域间路由

CIDR就是应用VLSM的方法,把一个IPv4地址划分为网络ID和主机ID两部分,当中网络ID的位数能够依据网络的规模来灵活配置。

在CIDR中使用CIDR标记法来表示网络ID的位数。即在一个IPv4地址后先加一斜线(/)。然后在斜线后面加上一个数字,该数字就是网络ID的位数,如192.168.1.123/24,这个地址的前24为是网络ID,后面8位是主机ID。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116656.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 勾勒Tor的全球使用情况

    勾勒Tor的全球使用情况

    2022年3月6日
    38
  • angular子组件传值到父组件_vue子组件传值给父组件

    angular子组件传值到父组件_vue子组件传值给父组件angular子组件传值给父组件step1: D:\vue\untitled2901\src\app\app.component.tsimport{Component}from’@angular/core’;@Component({selector:’app-root’,template:`Message:{{message}}<app-child(messageEvent)=”receiveMessage($event)”></app

    2025年9月15日
    7
  • cultureinfo 类 java_为国家,语言组合创建自定义CultureInfo

    cultureinfo 类 java_为国家,语言组合创建自定义CultureInfo我正在开发一个.net4.5应用程序,需要多语言支持多文化等.以下是国家/语言的示例列表俄罗斯/俄罗斯比利时/法国比利时/荷兰对于上述所有内容,可以根据上述文化名称创建CultureInfo对象ru-RUfr-BEnl-BE当用户进入站点时,我将Thread.CurrentThread.CurrentCulture和Thread.CurrentThread.CurrentUICulture设置…

    2022年6月19日
    24
  • tomcat 设置允许跨域访问「建议收藏」

    tomcat 设置允许跨域访问「建议收藏」既然想到使用tomcat进行跨域的设置,而不使用在项目中设置header来解决,说明你也是tomcat下的资源需要做跨域处理吧?这也是一个统一的允许跨域设置,tomcat下的所有请求都将放开,请注意。具体步骤:1.首先找到你的tomcat所在路径,并在conf文件夹下找到web.xml2.打开该文件,在以下位置加上这段:<filter><…

    2022年9月30日
    3
  • CTF——流量分析题型整理总结

    CTF——流量分析题型整理总结我见过的流量分析类型的题目总结:一,ping报文信息(icmp协议)二,上传/下载文件(蓝牙obex,http,难:文件的分段上传/下载)三,sql注入攻击四,访问特定的加密解密网站(md5,base64)五,后台扫描+弱密码爆破+菜刀六,usb流量分析七,WiFi无线密码破解八,根据一组流量包了解黑客的具体行为例题:一,ping报文信息(icm…

    2022年5月1日
    69
  • 5款强大的开源报表工具有哪些_开源报表工具 java

    5款强大的开源报表工具有哪些_开源报表工具 java作者:JEECG开源社区來源:简书最近发现几款不错的开源报表,还提供源码,现在给大家分享一下,希望能带来帮助!1、项目名称:积木报表项目简介:积木报表,免费的企业级WEB报表工具。专注于…

    2022年10月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号