IP地址计算方法Word格式文档下载.docx
《IP地址计算方法Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《IP地址计算方法Word格式文档下载.docx(19页珍藏版)》请在冰豆网上搜索。
IP地址的分类
为了方便IP寻址将IP地址划分为A、B、C、D和E五类,每类IP地址对各个IP地址中用来表示网络ID和主机ID的位数作了明确的规定。
当主机ID的位数确定之后,一个网络中是多能够包含的计算机数目也就确定,用户可根据企业需要灵活选择一类IP地址构建网络结构。
A类
A类地址用IP地址前8位表示网络ID,用IP地址后24位表示主机ID。
A类地址用来表示网络ID的第一位必须以0开始,其他7位可以是任意值,当其他7位全为0是网络ID最小,即为0;
当其他7位全为1时网络ID最大,即为127。
网络ID不能为0,它有特殊的用途,用来表示所有网段,所以网络ID最小为1;
网络ID也不能为127;
127用来作为网络回路测试用。
所以A类网络网络ID的有效范围是1-126共126个网络,每个网络可以包含224-2台主机。
B类
B类地址用IP地址前16位表示网络ID,用IP地址后16位表示主机ID。
B类地址用来表示网络ID的前两位必须以10开始,其他14位可以是任意值,当其他14位全为0是网络ID最小,即为128;
当其他14位全为1时网络ID最大,第一个字节数最大,即为191。
B类IP地址第一个字节的有效范围为128-191,共16384个B类网络;
每个B类网络可以包含216-2台主机(即65534台主机)。
C类
C类地址用IP地址前24位表示网络ID,用IP地址后8位表示主机ID。
C类地址用来表示网络ID的前三位必须以110开始,其他22位可以是任意值,当其他22位全为0是网络ID最小,IP地址的第一个字节为192;
当其他22位全为1时网络ID最大,第一个字节数最大,即为223。
C类IP地址第一个字节的有效范围为192-223,共2097152个C类网络;
每个C类网络可以包含28-2台主机(即254台主机)。
D类
D类地址用来多播使用,没有网络ID和主机ID之分,D类IP地址的第一个字节前四位必须以1110开始,其他28位可以是任何值,则D类IP地址的有效范围为到。
E类
E类地址保留实验用,没有网络ID和主机ID之分,E类IP地址的第一字节前四位必须以1111开始,其它28位可以是任何值,则E类IP地址的有效范围为至。
其中表示广播地址。
在实际应用中,只有A、B和C三类IP地址能够直接分配给主机,D类和E类不能直接分配给计算机。
三、
网络ID、主机ID和子网掩码
网络ID用来表示计算机属于哪一个网络,网络ID相同的计算机不需要通过路由器连接就能够直接通信,我们把网络ID相同的计算机组成一个网络称之为本地网络(网段);
网络ID不相同的计算机之间通信必须通过路由器连接,我们把网络ID不相同的计算机称之为远程计算机。
当为一台计算机分配IP地址后,该计算机的IP地址哪部份表示网络ID,哪部份表示主机ID,并不由IP地址所属的类来确定,而是由子网掩码确定。
子网确定一个IP地址属于哪一个子网。
子网掩码的格式是以连续的255后面跟连续的0表示,其中连续的255这部份表示网络ID;
连续0部份表示主机ID。
比如,子网掩码和。
根据子网掩码的格式可以发现,子网掩码有0.0.0.0、、、和共五种。
采用这种格式的子网掩码每个网络中主机的数目相差至少为256倍,不利于灵活根据企业需要分配IP地址。
比如,一个企业有2000台计算机,用户要么为其分配子网掩为,那么该网络可包含65534台计算机,将造成63534个IP地址的浪费;
要么用户为其分配8个网络,那么必须用路由器连接这个8个网络,造成网络管理和维护的负担。
网络ID是IP地址与子网掩码进行与运算获得,即将IP地址中表示主机ID的部份全部变为0,表示网络ID的部份保持不变,则网络ID的格式与IP地址相同都是32位的二进制数;
主机ID就是表示主机ID的部份。
例题1:
IP地址:
子网掩码:
网络ID:
主机ID:
例题2:
IP地址:
子网掩码:
网络ID:
35
四、
子网和CIDR
将常规的子网掩码转换为二进制,将发现子网掩格式为连续的二进制1跟连续0,其中子网掩码中为1的部份表示网络ID,子网掩中为0的表示主机ID。
比如转换为二进制为0000000000000000。
在前面所举的例子中为什么不用连续的1部份表示网络ID,连续的0部份表示主机ID呢?
答案是肯定的,采用这种方案的IP寻址技术称之为无类域间路由(CIDR)。
CIDR技术用子网掩码中连续的1部份表示网络ID,连续的0部份表示主机ID。
比如,网络中包含2000台计算机,只需要用11位表示主机ID,用21位表网络ID,则子网掩码表示为...00000000,转换为十进制则为。
此时,该网络将包含2046台计算机,既不会造成IP地址的浪费,也不会利用路由器连接网络,增加额外的管理维护量。
CIDR表示方法:
IP地址/网络ID的位数,比如,其中用21位表示网络ID。
子网掩码:
00000000则为网络ID:
(其中第三个字节红色部分表示网络ID,其他表示主机ID,网络ID是表示网络ID部份保持不变主机ID全部变为0)则网络ID为起始IP地址:
(主机ID不能全为0,全为0表示网络ID最后一位为1)
结束IP地址:
(主机ID不能全为1,全为1表示本地广播)则结束IP地址为:
。
将划分为16个子网,计算前两个子网的网络ID、子网掩码、起止IP地址。
第1步:
用CIDR表示,则子网掩码为().0。
第2步:
第一网络ID(子网掩码与IP地址与运算):
第一个IP地址:
结束IP地址:
;
第3步:
第二网络ID:
第一个IP地址:
五、
子网掩码和网络ID的快速计算
CIDR的子网掩码都是连续的1跟连接的0表示,则子网掩码有以下几种表示方法:
00000000 0
10000000 128
11000000 128+64=192
11100000 128+64+32=224
11110000 255-15=240
11111000 255-7=248
11111100 255-3=252
11111110 255-1=254
11111111 255
大家都知道的十进制数为255,那么我们怎么来快速计算子网掩码呢?
二进制的1=1,11=3,111=7,1111=15;
那么11111110=255-1,11111100=255-3,11111000=255-8,11110000=255-15这样是不是就很快呢?
只要我们一旦确定子网掩码中有多少位表示网络ID,那么我们马上就可以写出子网掩码了。
那么,对于10000000,11000000和11100000我们又该怎么计算呢?
27=8则10000000=128,11000000=128+64,11100000=128+64+32,所以我们不需要去记住每一个为多少,只需要做做简单的加减法就搞定子网掩码的计算。
网络ID的结果大家都知道网络ID部份不变,主机ID部分全部变为0,那么在计算网络ID时,首先看子网掩码中有多少位用来表示网络,相应在将IP地址转换为二进制时就只转换前面几位,比如,网络ID一共19位,则网络ID前两个字节为发生变化的为第三个字节。
那么怎样快速计算出这个变化的X的值呢?
我们知道第三字节只有三位表示网络ID,转换时176>
128,第1位为1,176-128=48<64,第2位为0,48>32第3位为1,剩下的计算就没有意义了,全都要转换为0,则网络ID为,则网络ID为,这样计算反而出错的可能性很小。
六、
本地和远程网络概念
网络ID相同的计算机称之为本地网络,本地网络中的计算机相互通信不需要路由器连接;
网络ID不相同的计算机称之为远程网络,远程网络中的计算机要相互通信必须通过路由器连接。
例题:
,,,哪些是合法IP,哪些是非法IP地址?
主机ID全为0和主机ID全为1的为非法IP地址:
、、都是非法IP地址。
,,哪个不是同一网段?
网络ID相同的就属于同一网段,则不属于同一网段。
七、
子网数和主机数的计算方法
,一共划分为了多少个子网,各子网可以包含多少台主机。
是一个B类地址,B类地址用16位表示网络ID,题目中20位表示网络ID,则子网位数为4位,那么子网就有24次个(即从0000、0001到1111的16种变化)。
由于IP地址是32位,用20位表示网络ID,则主机ID的位数为12位,则每个子网可以包含212-2个IP地址,即可以包含4096个IP地址。
注意:
为什么计算IP地址时要减2,而计算子网数目时不减2呢?
IP地址减2的原因是主机ID不能全为0也不能全为1;
子网就不存在这个问题。
八、
公共IP和私有IP地址
IP地址由IANA(Internet地址分配机构)管理和分配,任何一个IP地址要能够在Internet上使用就必须由IANA分配,IANA分配的能够在Internet上正常使用的IP地址称之为公共IP地址;
IANA保留了一部份IP地址没有分配给任何机构和个人,这部份IP地址不能在Internet上使用,此类IP地址就称之为私有IP地址。
为什么私有IP地址不能在Internet上使用呢?
因为Internet上没有私有IP地址的路由。
私有IP地址范围包括:
A类:
10.0.0.0/8
B类:
即共16个B类网络
C类:
即共256个C类网络
九、
路由概念、Ping、Ipconfig、Route和Tracert命令
通过路由器将数据从一个网络传输到另一个网络称之为路由。
路由选择负责在网络中选择一段最优先的路径将数据传输到目的网络,路由选择的基础和依据是路由表,路由表由目的网络ID、子网掩码、网关、接口和计费组成,通过routeprint可查看计算机的路由表。
Ping命令的三种结果
目的地不可到达:
路由表无目的地记录
超时:
网关设置错有路由表记录
ping命令详解
系统内置的网络测试工具ping
1.Ping命令的语法格式ping命令看似小小的一个工具,但它带有许多参数,要完全掌握它的使用方法还真不容易,要达到熟练使用则更是难下加难,但不管怎样我们还得来看看它的真面目,首先我们还是从最基本的命令格式入手吧!
ping命令的完整格式如下:
ping[-t][-a][-ncount][-llength][-f][-ittl][-vtos][-rcount][-scount][-j-Hostlist]|[-kHost-list][-wtimeout]destination-list
从这个命令式中可以看出它的复杂程度,ping命令本身后面都是它的执行参数,现对其参数作一下详细讲解吧!
-t——有这个参数时,当你ping一个主机时系统就不停的运行ping这个命令,直到你按下Control-C。
-a——解析主机的NETBIOS主机名,如果你想知道你所ping的要机计算机名则要加上这个参数了,一般是在运用ping命令后的第一行就显示出来。
-ncount——定义用来测试所发出的测试包的个数,缺省值为4。
通过这个命令可以自己定义发送的个数,对衡量网络速度很有帮助,比如我想测试发送20个数据包的返回的平均时间为多少,最快时间为多少,最慢时间为多少就可以通过执行带有这个参数的命令获知。
-llength——定义所发送缓冲区的数据包的大小,在默认的情况下windows的ping发送的数据包大小为32byt,也可以自己定义,但有一个限制,就是最大只能发送65500byt,超过这个数时,对方就很有可能因接收的数据包太大而死机,所以微软公司为了解决这一安全漏洞于是限制了ping的数据包大小。
-f——在数据包中发送“不要分段”标志,一般你所发送的数据包都会通过路由分段再发送给对方,加上此参数以后路由就不会再分段处理。
-ittl——指定TTL值在对方的系统里停留的时间,此参数同样是帮助你检查网络运转情况的。
-vtos——将“服务类型”字段设置为“tos”指定的值。
-rcount——在“记录路由”字段中记录传出和返回数据包的路由。
一般情况下你发送的数据包是通过一个个路由才到达对方的,但到底是经过了哪些路由呢?
通过此参数就可以设定你想探测经过的路由的个数,不过限制在了9个,也就是说你只能跟踪到9个路由。
-scount——指定“count”指定的跃点数的时间戳,此参数和-r差不多,只是这个参数不记录数据包返回所经过的路由,最多也只记录4个。
-jhost-list——利用“computer-list”指定的计算机列表路由数据包。
连续计算机可以被中间网关分隔IP允许的最大数量为9。
-khost-list——利用“computer-list”指定的计算机列表路由数据包。
连续计算机不能被中间网关分隔IP允许的最大数量为9。
-wtimeout——指定超时间隔,单位为毫秒。
destination-list——是指要测试的主机名或IP地址
-t参数-t——有这个参数时,当你ping一个主机时系统就不停的运行ping这个命令,直到你按下Control-C。
例如:
C:
\WINDOWS>
ping-t
Pingingwith32bytesofdata:
Replyfrombytes=32time<
10msTTL=64
Replyfrombytes=32time<
PingstatisticsforPackets:
Sent=8,Received=8,Lost=0(0%loss),Approximateroundtriptimesinmilli-seconds:
Minimum=0ms,Maximum=0ms,Average=0msControl-C
-a参数-a——解析主机的NETBIOS主机名,如果你想知道你所ping的要机计算机名则要加上这个参数了,一般是在运用ping命令后的第一行就显示出来。
ping-a
Pinging000[with32bytesofdata:
10msTTL=128
Sent=4,Received=4,Lost=0(0%loss),Approximateroundtriptimesinmilli-seconds:
Minimum=0ms,Maximum=0ms,Average=0ms
可以得知:
ip为的计算机,NETBIOS名为000
再如:
Pinging[with32bytesofdata:
ip为的计算机,NETBIOS名为9
-n参数-ncount——定义用来测试所发出的测试包的个数,缺省值为4。
ping-n10
Sent=10,Received=10,Lost=0(0%loss)Approximateroundtriptimesinmilli-seconds:
Minimum=0ms,Maximum=0ms,Average=0ms向IP为的计算机,发送10个数据包,发送10个,返回10个,没有丢包。
-l参数-llength——定义所发送缓冲区的数据包的大小,在默认的情况下windows的ping发送的数据包大小为32byt,也可以自己定义,但有一个限制,就是最大只能发送65500byt,超过这个数时,对方就很有可能因接收的数据包太大而死机,所以微软公司为了解决这一安全漏洞于是限制了ping的数据包大小。
ping-l32768-n10
Pingingwith32768bytesofdata:
Requesttimedout.
Replyfrombytes=32768time=12msTTL=64
Replyfrombytes=32768time=9msTTL=64
Sent=10,Received=9,Lost=1(10%loss),Approximateroundtriptimesinmilli-seconds:
Minimum=9ms,Maximum=12ms,Average=9ms向IP为的计算机,发送大小为32768byt的数据包10个,发送10个,返回9个,丢失1个。
返回数据包最短时间为9ms,最长时间为12ms。
2.Ping命令的应用
(1)、测试网络的通畅我们知道可以用ping命令来测试一下网络是否通畅,这在局域网的维护中经常用到,方法很简单,只需要在DOS或Windows的开始菜单下的“运行”子项中用ping命令加上所要测试的目标计算机的IP地址或主机名即可(目标计算机要与你所运行ping命令的计算机在同一网络或通过电话线或其它专线方式已连接成一个网络),其它参数可全不加。
如要测试台IP地址为的工作站与服务器是否已连网成功,就可以在服务器上运行:
ping-a即可,如果工作站上TCP/IP协议工作正常,即会以DOS屏幕方式显示如下所示的信息:
C:
Minimum=0ms,Maximum=0ms,Average=0ms从上面我们就可以看出目标计算机与服务器连接成功,TCP/IP协议工作正常,因为加了“-a”这个参数所以还可以知道IP为的计算机的NetBIOS名为9。
下面我们来PINGIP为的计算机,如果网络未连成功则显示如下错误信息:
ping
Requesttimedout.
Pingstatisticsfor