Linux系统的route命令用于显示和操作IP路由表(show / manipulate the IP routing table)。要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现。在Linux系统中,设置路由通常是为了解决以下问题:该Linux系统在一个局域网中,局域网中有一个网关,能够让机器访问Internet,那么就需要将这台机器的IP地址设置为Linux机器的默认路由。要注意的是,直接在命令行下执行route命令来添加路由,不会永久保存,当网卡重启或者机器重启之后,该路由就失效了;可以在/etc/rc.local中添加route命令来保证该路由设置永久有效。

1.命令格式:

  route [-f] [-p] [Command [Destination] [mask Netmask] [Gateway] [metric Metric]] [if Interface]]

2.命令功能:

  Route命令是用于操作基于内核ip路由表,它的主要作用是创建一个静态路由让指定一个主机或者一个网络通过一个网络接口,如eth0。当使用"add"或者"del"参数时,路由表被修改,如果没有参数,则显示路由表当前的内容。

3.命令参数:

  -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 命令的显示功能。可以使用十进制或十六进制值进行接口索引。

4.使用实例:

实例1:显示当前路由

命令:

  route

  route -n

输出:

[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
e192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
[root@localhost ~]# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
0.0.0.0 192.168.120.240 0.0.0.0 UG 0 0 0 eth0

说明:

  第一行表示主机所在网络的地址为192.168.120.0,若数据传送目标是在本局域网内通信,则可直接通过eth0转发数据包;

  第四行表示数据传送目的是访问Internet,则由接口eth0,将数据包发送到网关192.168.120.240

  其中Flags为路由标志,标记当前网络节点的状态。

  Flags标志说明:

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

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

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

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

  D Dynamically,此路由是动态性地写入

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

  ! 表示此路由当前为关闭状态

备注:

  route -n (-n 表示不解析名字,列出速度会比route 快)

实例2:添加网关/设置网关

命令:

  route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0

输出:

[root@localhost ~]# route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0
[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
224.0.0.0 * 240.0.0.0 U 0 0 0 eth0
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0

说明:

  增加一条 到达244.0.0.0的路由

实例3:屏蔽一条路由

命令:

  route add -net 224.0.0.0 netmask 240.0.0.0 reject

输出:

[root@localhost ~]# route add -net 224.0.0.0 netmask 240.0.0.0 reject
[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
224.0.0.0 - 240.0.0.0 ! 0 - 0 -
224.0.0.0 * 240.0.0.0 U 0 0 0 eth0
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
[root@localhost ~]#

说明:

  增加一条屏蔽的路由,目的地址为 224.x.x.x 将被拒绝

实例4:删除路由记录

命令:

  route del -net 224.0.0.0 netmask 240.0.0.0

  route del -net 224.0.0.0 netmask 240.0.0.0 reject

输出:

[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
224.0.0.0 - 240.0.0.0 ! 0 - 0 -
224.0.0.0 * 240.0.0.0 U 0 0 0 eth0
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
[root@localhost ~]# route del -net 224.0.0.0 netmask 240.0.0.0
[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
224.0.0.0 - 240.0.0.0 ! 0 - 0 -
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
[root@localhost ~]# route del -net 224.0.0.0 netmask 240.0.0.0 reject
[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
[root@localhost ~]#

说明:

实例5:删除和添加设置默认网关

命令:

  route del default gw 192.168.120.240

  route add default gw 192.168.120.240

输出:

[root@localhost ~]# route del default gw 192.168.120.240
[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
[root@localhost ~]# route add default gw 192.168.120.240
[root@localhost ~]# route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
[root@localhost ~]#

最新文章

  1. ASP.NET MVC Model验证(五)
  2. 初学python第一天
  3. unserialize函数中的参数是否是污染数据
  4. ibatis动态sql配置启动时提示:The content of elements must consist of well-formed character data...
  5. Android——不同activity之间数据传递
  6. c# 如何获取项目的根目录
  7. Javascript获取某个月的天数-简单方法 .(转别人的)
  8. Qt判断和打开进程(windows端),运行,检测,中止
  9. 网页解析不了PHP源代码的解决方法
  10. cocos2d-x游戏开发系列教程-坦克大战游戏之虚拟手柄控制坦克移动
  11. 浅谈Jquery的使用下篇
  12. (5)java中的常用API,其实就是一些常见类的使用
  13. 生成淘口令发现的一个趣事 c#
  14. Mina源码阅读笔记(三)-Mina的连接IoAccpetor
  15. 又拍云张聪:OpenResty 动态流控的几种姿势
  16. Date、Calendar、DateFormat类
  17. poj 2482 Stars in Your Window + 51Nod1208(扫描线+离散化+线段树)
  18. node-webkit,nwjs 打包启动启动很慢解决办法
  19. SAP函数 CS_WHERE_USED_MAT 反查上层BOM
  20. Mixed Content: The page at 'https://a.t.com/login' was loaded over HTTPS, but requested an insecure stylesheet 非全站https

热门文章

  1. 2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018) Solution
  2. ng-深度学习-课程笔记-14: 人脸识别和风格迁移(Week4)
  3. 20145311王亦徐《JAVA程序设计》课程总结
  4. Block作为参数时的使用
  5. Ubuntu16.04编译安装tensorflow,2018最新血泪踩坑之后的全面总结!绝对成功!【转】
  6. linux内核源码在线浏览
  7. 【查看内存】Linux查看内存使用情况(一)
  8. UVa 557 汉堡
  9. 代理模式:利用JDK原生动态实现AOP
  10. MVP框架模式