0.0.0.0 详解

简介: <p style="color:rgb(51,51,51); font-family:Arial; font-size:14px; line-height:26px; text-indent:2em"> <span style="font-family:'courier new',courier">RFC:</span></p> <p style="color:rgb(51,51,51

RFC:

0.0.0.0/8 - Addresses in this block refer to source hosts on "this"
network. Address 0.0.0.0/32 may be used as a source address for this
host on this network; other addresses within 0.0.0.0/8 may be used to
refer to specified hosts on this network ([RFC1122],Section 3.2.1.3).

因此,根据RFC文档描述,它不只是代表本机,0.0.0.0/8可以表示本网络中的所有主机,0.0.0.0/32可以用作本机的源地址,0.0.0.0/8也可表示本网络上的某个特定主机,综合起来可以说0.0.0.0表示整个网络

在路由器配置中可用0.0.0.0/0表示默认路由,作用是帮助路由器发送路由表中无法查询的包。如果设置了全零网络的路由,路由表中无法查询的包都将送到全零网络的路由中去。

查阅百度知道里一些说法如下:

1. 严格说来,0.0.0.0已经不是一个真正意义上的IP地址了。它表示的是这样一个集合:所有不清楚的主机和目的网络。这里的“不清楚”是指在本机的路由表里没有特定条目指明如何到达。对本机来说,它就是一个“收容所”,所有不认识的“三无”人员,一 律送进去。如果你在网络设置中设置了缺省网关,那么Windows系统会自动产生一个目的地址为0.0.0.0的缺省路由。

2. 网络中0.0.0.0的IP地址表示整个网络,即网络中的所有主机。它的作用是帮助路由器发送路由表中无法查询的包。如果设置了全零网络的路由,路由表中无法查询的包都将送到全零网络的路由中去。

3.若IP地址全为0,也就是0.0.0.0,则这个IP地址在IP数据报中只能用作源IP地址,这发生在当设备启动时但又不知道自己的IP地址情况下。在使用DHCP分配IP地址的网络环境中,这样的地址是很常见的。用户主机为了获得一个可用的IP地址,就给DHCP服务器发送IP分组,并用这样的地址作为源地址,目的地址为255.255.255.255(因为主机这时还不知道DHCP服务器的IP地址)。


route详解:

 -f 清除所有不是主路由 ( 子网掩码为 255.255.255.255 的路由 ) 、环回网络路由 ( 目标为 127.0.0.0 ,子网掩码为 255.255.255.0 的路由 ) 或多播路由 ( 目标为 224.0.0.0 ,子网掩码为 240.0.0.0 的路由 ) 的条目的路由表。 如果它与命令之一 ( 例如 Add 、 Change 或 Delete) 结合使用,表会在运行命令之前清除。

  -p 与 Add 命令共同使用时,指定路由被添加到注册表并在启动 TCP/IP 协议的时候初始化 IP 路由表。 默认情况下,启动 TCP/IP 协议时不会保存添加的路由 , 与 Print 命令一起使用时,则显示永久路由列表。所有其他的命令都忽略此参数。永久路由存储在注册表中的位置是 HKEY_LOCAL_MACHSYSTEMCurrentControlSetServicesTcpipParametersPersistentRoutes 。

  command 指定要运行的命令。 下表列出了有效的命令。

  destination 指定路由的网络目标地址。 目标地址可以是一个 IP 网络地址 ( 其中网络地址的主机地址位设置为 0) ,对于主机路由是 IP 地址,对于默认路由是 0.0.0.0 。 mask subnetmask 指定与网络目标地址相关联的网掩码 ( 又称子网掩码 ) 。子网掩码对于 IP 网络地址可以是一适当的子网掩码,对于主机路由是 255.255.255.255 ,对于默认路由是 0.0.0.0 。如果忽略,则使用子网掩码 255.255.255.255 。定义路由时由于目标地址和子网掩码之间的关系,目标地址不能比它对应的子网掩码更为详细。换句话说,如果子网掩码的一位是 0 ,则目标地址中的对应位就不能设置为 1 。
gateway 指定超过由网络目标和子网掩码定义的可达到的地址集的前一个或下一个跃点 IP 地址。 对于本地连接的子网路由,网关地址是分配给连子网接口的 IP 地址。对于要经过一个或多个路由器才可用到的远程路由,网关地址是一个分配给相邻路由器的、可直接达到的 IP 地址。

  metric metric 为路由指定所需跃点数的整数值 ( 范围是 1 ~ 9999) ,它用来在路由表里的多个路由中选择与转发包中的目标地址最为匹配的路由。 所选的路由具有最少的跃点数。跃点数能够反映跃点的数量、路径的速度、路径可靠性、路径吞吐量以及管理属性。

  if interface 指定目标可以到达的接口的接口索引。 使用 Route print 命令可以显示接口及其对应接口索引的列表。对于接口索引可以使用十进制或十六进制的值。对于十六进制值,要在十六进制数的前面加上 0x 。忽略 if 参数时,接口由网关地址确定。

  注意:路由表中跃点数一列的值较大是由于允许 TCP/IP 根据每个 LAN 接口的 IP 地址、子网掩码和默认网关的配置自动确定路由表中路由的跃点数造成的。默认启动的自动确定接口跃点数确定了每个接口的速度,调整了每个接口的路由跃点数,因此最快接口所创建的路由具有最低的跃点数。要删除大跃点数,请在每个 LAN 连接的 TCP/IP 协议的高级属性中禁用自动确定接口跃点数。
如果在 systemrootSystem32DriversEtc 文件夹的本地网络文件中存在适当的条目,名称可以用于 Destination 。只要名称可以通过 “ 域名系统 ”(DNS) 查询这样的标准主机名解析技术分解为 IP 地址,就可以将其用于 Gateway , DNS 查询使用存储在 systemrootSystem32DriversEtc 文件夹下的本地主机文件和 NetBIOS 名称解析。

  如果是 Print 或 Delete 命令,可以忽略 Gateway 参数,使用通配符来表示目标和网关。 Destination 的值可以是由星号 (*) 指定的通配符。如果指定目标含有一个星号 (*) 或问号 (?) ,它被看作是通配符,只打印或删除匹配的目标路由。星号代表任意一字符序列,问号代表任一字符。例如, 10.*.1 、 192.168.* 、 127.* 和 *224* 都是星号通配符的有效使用。
使用了无效的目标和子网掩码 ( 网掩码 ) 值的组合,会显示 “Route bad gateway address netmask” 错误消息。目标中有一位或多位设置为 1 ,而其在子网掩码中的对应位设置为 0 时会发生这个错误。可以通过二进制表示法表示目标和子网掩码来检查这种情况。以二进制表示的子网掩码包括表示目标网络地址部分的一连串的 1 和表示目标主机地址部分的一连串的 0 两个部分。查看目标以确定目标的主机地址部分 ( 由子网掩码所定义 ) 是否有些位设置成了 1 。

  Windows 98 的 Route 命令不支持 -p 参数。

  只有当 TCP/IP 协议在网络连接中安装为网络适配器属性的组件时,该命令才可用。

4. 例举说明

例子 1 :查看 route 所有参数

例子 2 :显示 IP 路由表的完整内容

例子 3 :要显示 IP 路由表中以 192. 开始的路由

例子 4 :添加默认网关地址为 192.168.1.7 的默认路由

例子 5 :添加目标为 10.41.0.0 ,子网掩码为 255.255.0.0 ,下一个跃点地址为 10.27.0.1 的路由,执行以下命令:

  route add 10.41.0.0 mask 255.255.0.0 10.27.0.1

例子 6 :要添加目标为 10.41.0.0 ,子网掩码为 255.255.0.0 ,下一个跃点地址为 10.27.0.1 的永久路由,执行以下命令:

  route -p add 10.41.0.0 mask 255.255.0.0 10.27.0.1


例子 7 :要添加目标为 10.41.0.0 ,子网掩码为 255.255.0.0 ,下一个跃点地址为 10.27.0.1 ,跃点数为 7 的路由,执行以下命令:

  route add 10.41.0.0 mask 255.255.0.0 10.27.0.1 metric 7


例子 8 :要添加目标为 10.41.0.0 ,子网掩码为 255.255.0.0 ,下一个跃点地址为 10.27.0.1 ,接口索引为 0x3 的路由,执行以下命令:

  route add 10.41.0.0 mask 255.255.0.0 10.27.0.1 if 0x3


例子 9 :要删除目标为 10.41.0.0 ,子网掩码为 255.255.0.0 的路由,执行以下命令:

  route delete 10.41.0.0 mask 255.255.0.0


例子 10 :要删除 IP 路由表中以 10. 开始的所有路由,执行以下命令:

  route delete 10.*


例子 11 :要将目标为 10.41.0.0 ,子网掩码为 255.255.0.0 的路由的下一个跃点地址由 10.27.0.1 更改为 10.27.0.25 ,执行以下命令:

  route change 10.41.0.0 mask 255.255.0.0 10.27.0.25 





目录
相关文章
|
域名解析 SEO 搜索推荐
网络基础知识之————A记录和CNAME记录的区别
1、什么是域名解析? 域名解析就是国际域名或者国内域名以及中文域名等域名申请后做的到IP地址的转换过程。IP地址是网路上标识您站点的数字地址,为了简单好记,采用域名来代替ip地址标识站点地址。域名的解析工作由DNS服务器完成。
7855 0
|
应用服务中间件 nginx 数据安全/隐私保护
nginx中session ticket重用Session提高https性能分析
使用session ticket机制可以提高ssl握手的效率,并节约有效的服务器计算资源
14747 0
|
存储 算法 网络协议
计算机网络(自顶向下)学习笔记——路由选择算法
本章学习路由选择算法,有部分内容未进行笔记的记录,想要了解的小伙伴可以查阅《计算机网络—自顶向下方法》这本书
359 0
计算机网络(自顶向下)学习笔记——路由选择算法
|
机器人 测试技术 数据库
聊一聊,Python自动化测试框架
在Python语言系中,有很多可用的自动化测试框架,比如早期大多数人会选用 unittest+HTMLTestRunner、Nose等,最近几年比较常用的有Robot Framework,Robot Framework它是Python下一款非常通用的测试框架,采用扩展插件的机制可以帮助我们实现几乎任何类型的自动化测试工作,如接口自动化测试、App自动化测试、Web UI自动化测试等。
689 0
|
机器学习/深度学习 数据采集 人工智能
机器学习基础:大数据与深度学习的关系
机器学习基础:大数据与深度学习的关系
285 0
机器学习基础:大数据与深度学习的关系
|
网络架构 网络安全
PREROUTING 和 POSTROUTING, SNAT 和 DNAT图文解析(非常清淅)
NAT (网络地址转换) 技术在平时是很多见的,如家庭中在使用路由器共享上网时,一般用的就是 NAT 技术,它可以实现众多内网 IP 共享一个公网 IP 上网。NAT 的原理 简单的说就是当内网主机访问外网时,当内网主机的数据包要通过路由器时,路由器将数据包中的源内网 IP 地址改为路由器上的公网 IP 地址,同时记录下该数据包的消息;当外网服务器响应这次由内而外发出的请求或数据交换时,当
4110 0
|
网络协议 Go Python
go 程序模拟僵尸进程实战
避免后续写代码出现僵尸进程,特此实战记录一把
|
存储 Kubernetes Unix
浅析 CSI 工作原理
CSI 的 cloud providers 有两种类型,一种为 in-tree 类型,一种为 out-of-tree 类型。前者是指运行在 k8s 核心组件内部的存储插件;后者是指独立在 k8s 组件之外运行的存储插件。本文主要介绍 out-of-tree 类型的插件。
978 0
|
缓存 网络协议 安全
TCP/UDP常见协议端口对照表【整理,持续更新】
TCP/UDP常见协议端口对照表,持续更新。
7130 0