route 命令详解

本贴最后更新于 2283 天前,其中的信息可能已经时过境迁

Route

功能简述:linux 系统中的 route 命令能够用于 IP 路由表的显示和操作。它的主要作用是创建一个静态路由让指定一个主机或者一个网络通过一个网络接口,如 eth0。当使用"add"或者"del"参数时,路由表被修改,如果没有参数,则显示路由表当前的内容。在一个网络中,需要一个路由器来转发不同广播域之间的数据,或是转发 lan 和 internet 之间的数据。有时我们需要设定这个路由器作为 linux 系统的默认路由,那么就可以通过 route 命令来操作。甚至我们也可以用我们的 linux 系统来充当路由器。

要注意的是,直接在命令行下执行 route 命令来添加路由,不会永久保存,当网卡重启或者机器重启之后,该路由就失效了;可以在/etc/rc.local 中添加 route 命令来保证该路由设置永久有效。当然如果加上了-p 参数的话那就会永久的生效了。

命令格式:route [-f] [-p] [Command [Destination] [mask Netmask] [Gateway][metric Metric]] [if Interface]]

命令参数:

-c 显示更多信息

-n 不解析名字

-v 显示详细的处理信息

-F 显示发送信息

-C 显示路由缓存

-f 清除所有网关入口的路由表。

-p 与 add 命令一起使用时使路由具有永久性。

add:添加一条新路由。

del:删除一条路由。

-net:目标地址是一个网络。

-host:目标地址是一个主机。

netmask:当添加一个网络路由时,需要使用网络掩码。

gw:路由数据包通过网关。注意,你指定的网关必须能够达到。

metric:设置路由跳数。

Command 指定您想运行的命令 (Add/Change/Delete/Print)。

Destination 指定该路由的网络目标。

mask Netmask 指定与网络目标相关的网络掩码(也被称作子网掩码)。

Gateway 指定网络目标定义的地址集和子网掩码可以到达的前进或下一跃点 IP 地址。

metric Metric 为路由指定一个整数成本值标(从 1 至 9999),当在路由表(与转发的数据包目标地址最匹配)的多个路由中进行选择时可以使用。

if Interface 为可以访问目标的接口指定接口索引。若要获得一个接口列表和它们相应的接口索引,使用 route print 命令的显示功能。可以使用十进制或十六进

(1)显示路由信息

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

Flags 标志说明:

U Up 表示此路由当前为启动状态

H Host,表示此网关为一主机

G Gateway,表示此网关为一路由器

R Reinstate Route,使用动态路由重新初始化的路由

D Dynamically,此路由是动态性地写入–》什么时候才会有动态的路由信息呢?

M Modified,此路由是由路由守护程序或导向器动态修改

(2)添加一条指向某个网络的路由

[root@LiWenTong ~]# route add -net 10.0.0.0 netmask 255.255.255.0 dev eth0—》这里是指定这条路由的出口在哪里。绿色部分:为指定目标网络的参数,需要 ip 地址或地址范围、子网掩码用于确定网络范围。

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

10.0.0.0 * 255.255.255.0 U 0 0 0 eth0

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

自我小结:route 添加路由都是需要指定目标网络,及路由出口这两个参数。记住加上-p 选项能永久添加。

(3)再来一条添加到某一个 ip 的路由

[root@LiWenTong ~]# route add -host 192.168.40.1dev eth0

[root@LiWenTong ~]# route ----》可以发现添加的是主机的话,默认是会帮我们添加一个全 255 的子网掩码,表示子网范围就只有一个而已,那就是这台主机啦。

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.1 * 255.255.255.255 UH 0 0 0 eth0

(4)屏蔽某一路由

当我们不让系统到达某个子网范围或者某个主机是就可以手动的来进行屏蔽。

[root@LiWenTong ~]# route add -net 10.10.10.128 netmask 255.255.255.128 reject—》前面部分是一样的,因为我们都是手动来添加一个路由嘛。只是在命令的最后不一样,我们指定的出口去而是 reject(拒绝),也就是拒绝出口。达到屏蔽的效果。还有看下 flags 会显示一个!

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.1 * 255.255.255.255 UH 0 0 0 eth0

10.10.10.128 - 255.255.255.128 ! 0 - 0 -

10.0.0.0 * 255.255.255.0 U 0 0 0 eth0

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

(5)删除路由

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.1 * 255.255.255.255UH 0 0 0 eth0

10.10.10.128 - 255.255.255.128 ! 0 - 0 -

10.0.0.0 * 255.255.255.0 U 0 0 0 eth0

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

[root@LiWenTong ~]# route del -net 10.10.10.128netmask 255.255.255.128 reject

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.1 * 255.255.255.255UH 0 0 0 eth0

10.0.0.0 * 255.255.255.0 U 0 0 0 eth0

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

说明:看到没有,路由已经被我删除掉了,哈哈哈哈。删除路由时,最好是看着路由表上的照样打进去,这样比较不会删错的。

(6)添加删除默认网关

[root@LiWenTong ~]# route add default gw 192.168.40.2

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.1 * 255.255.255.255UH 0 0 0 eth0

10.0.0.0 * 255.255.255.0 U 0 0 0 eth0

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.2 0.0.0.0 UG 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

--》可以看到此处有两个默认网关,那到底路由会走哪个呢?

[root@LiWenTong ~]# route del default gw192.168.40.2--- 》在这里我们还是先删除掉吧。

[root@LiWenTong ~]# route

Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

192.168.40.1 * 255.255.255.255UH 0 0 0 eth0

10.0.0.0 * 255.255.255.0 U 0 0 0 eth0

192.168.40.0 * 255.255.252.0 U 0 0 0 eth0

169.254.0.0 * 255.255.0.0 U 0 0 0 eth0

default 192.168.40.1 0.0.0.0 UG 0 0 0 eth0

---------------------------后续自我小结-------------------------

很好,这个 route 命令好像跟 windows 的 route 命令差不多。主要就是查看 route 表,添加一条路由啦。添加默认路由啦,删除路由啦。这边还多了个屏蔽路由 reject。

route add -net 192.168.40.0 netmask 255.255.255.0 dev eth0:1

route add -host 192.168.40.111 dev eth0 reject

route del -net 192.168.40.0 netmask 255.255.255.0 dev eth0:1

route add default gw 192.169.1.1

后续我还会在网络查看是否别人有一些其他比较常用的环境。大家有知道也帮我留下哦!

来自 [http://www.centoscn.com/CentOS/help/2014/0113/2351.html](http://www.centoscn.com/CentOS/help/2014/0113/2351.html)

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 153 回帖
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 94 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 351 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 376 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    83 引用 • 37 回帖 • 1 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    287 引用 • 4484 回帖 • 669 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 327 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 764 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    169 引用 • 506 回帖
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 19 关注
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 664 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 26 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    91 引用 • 751 回帖 • 2 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1705 回帖 • 1 关注
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    4 引用 • 16 回帖 • 5 关注
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 173 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1348 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    729 引用 • 1327 回帖
  • SEO

    发布对别人有帮助的原创内容是最好的 SEO 方式。

    35 引用 • 200 回帖 • 22 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 585 关注
  • 以太坊

    以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。

    34 引用 • 367 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    690 引用 • 535 回帖
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 700 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 483 关注