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

输出:

  1. [root@localhost ~]# route
  2. Kernel IP routing table
  3. Destination Gateway Genmask Flags Metric Ref Use Iface
  4. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  5. e192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  6. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  7. default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
  8. [root@localhost ~]# route -n
  9. Kernel IP routing table
  10. Destination Gateway Genmask Flags Metric Ref Use Iface
  11. 192.168.120.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
  12. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  13. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  14. 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

输出:

  1. [root@localhost ~]# route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0
  2. [root@localhost ~]# route
  3. Kernel IP routing table
  4. Destination Gateway Genmask Flags Metric Ref Use Iface
  5. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  6. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  7. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  8. 224.0.0.0 * 240.0.0.0 U 0 0 0 eth0
  9. 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

输出:

  1. [root@localhost ~]# route add -net 224.0.0.0 netmask 240.0.0.0 reject
  2. [root@localhost ~]# route
  3. Kernel IP routing table
  4. Destination Gateway Genmask Flags Metric Ref Use Iface
  5. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  6. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  7. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  8. 224.0.0.0 - 240.0.0.0 ! 0 - 0 -
  9. 224.0.0.0 * 240.0.0.0 U 0 0 0 eth0
  10. default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
  1. [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

输出:

  1. [root@localhost ~]# route
  2. Kernel IP routing table
  3. Destination Gateway Genmask Flags Metric Ref Use Iface
  4. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  5. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  6. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  7. 224.0.0.0 - 240.0.0.0 ! 0 - 0 -
  8. 224.0.0.0 * 240.0.0.0 U 0 0 0 eth0
  9. default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
  10. [root@localhost ~]# route del -net 224.0.0.0 netmask 240.0.0.0
  11. [root@localhost ~]# route
  12. Kernel IP routing table
  13. Destination Gateway Genmask Flags Metric Ref Use Iface
  14. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  15. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  16. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  17. 224.0.0.0 - 240.0.0.0 ! 0 - 0 -
  18. default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
  19. [root@localhost ~]# route del -net 224.0.0.0 netmask 240.0.0.0 reject
  20. [root@localhost ~]# route
  21. Kernel IP routing table
  22. Destination Gateway Genmask Flags Metric Ref Use Iface
  23. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  24. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  25. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  26. default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
  27. [root@localhost ~]#

说明:

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

命令:

  route del default gw 192.168.120.240

  route add default gw 192.168.120.240

输出:

  1. [root@localhost ~]# route del default gw 192.168.120.240
  2. [root@localhost ~]# route
  3. Kernel IP routing table
  4. Destination Gateway Genmask Flags Metric Ref Use Iface
  5. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  6. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  7. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  8. [root@localhost ~]# route add default gw 192.168.120.240
  9. [root@localhost ~]# route
  10. Kernel IP routing table
  11. Destination Gateway Genmask Flags Metric Ref Use Iface
  12. 192.168.120.0 * 255.255.255.0 U 0 0 0 eth0
  13. 192.168.0.0 192.168.120.1 255.255.0.0 UG 0 0 0 eth0
  14. 10.0.0.0 192.168.120.1 255.0.0.0 UG 0 0 0 eth0
  15. default 192.168.120.240 0.0.0.0 UG 0 0 0 eth0
  16. [root@localhost ~]#

每天一个linux命令(网络):【转载】route命令的更多相关文章

  1. linux查看网络链接状况命令netstat

    linux查看网络链接状况命令 netstat 参数如下: -a 显示所有socket,包括正在监听的. -c 每隔1秒就重新显示一遍,直到用户中断它. -i 显示所有网络接口的信息,格式同“ifco ...

  2. linux命令总结之route命令

    route命令用于显示和操作IP路由表.要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现.在Linux系统中,设置路由通常是 为了解决以下问题:该Linu ...

  3. Linux命令学习手册-route命令

    route [-CFvnee] route [-v]  [-A family] add [-net|-host] target [netmask Nm] [gw Gw] [metric N] [mss ...

  4. 每天一个linux命令(53):route命令

    Linux系统的route命令用于显示和操作IP路由表(show / manipulate the IP routing table).要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或 ...

  5. 每天一个linux命令:route命令

    Linux系统的route命令用于显示和操作IP路由表(show / manipulate the IP routing table).要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或 ...

  6. 每天一个linux命令(45):route命令

    Linux系统的route 命令用于显示和操作IP路由表(show / manipulate the IP routing table).要实现两个不同的子网之间的通信,需 要一台连接两个网络的路由器 ...

  7. 【转】每天一个linux命令(53):route命令

    原文网址:http://www.cnblogs.com/peida/archive/2013/03/05/2943698.html Linux系统的route命令用于显示和操作IP路由表(show / ...

  8. 【转载】每天一个Linux命令

    目  录 每天一个linux命令(1)  : ls 命令 每天一个linux命令(2)  : cd 命令 每天一个linux命令(3)  : pwd 命令 每天一个linux命令(4)  : mkdi ...

  9. linux 命令总结(转载)

    linux 命令总结(转载) 1. 永久更改ip ifconfig eth0 新ip 然后编辑/etc/sysconfig/network-scripts/ifcfg-eth0,修改ip 2.从Lin ...

  10. Linux命令学习(18):route命令

    版权声明更新:2017-05-20博主:LuckyAlan联系:liuwenvip163@163.com声明:吃水不忘挖井人,转载请注明出处! 1 文章介绍 本文介绍了Linux下面的route命令. ...

随机推荐

  1. http之http1.0和http1.1的区别

    下面主要从几个不同的方面介绍HTTP/1.0与HTTP/1.1之间的差别,当然,更多的内容是放在解释这种差异背后的机制上. 1 可扩展性 可扩展性的一个重要原则:如果HTTP的某个实现接收到了自身未定 ...

  2. http之url和uri

    HTTP使用统一资源标识符(Uniform Resource Identifiers, URI)来传输数据和建立连接.URL是一种特殊类型的URI,包含了用于查找某个资源的足够的信息 URL,全称是U ...

  3. devise 自定义手机号登录

    user model中配置 validates_uniqueness_of :phone def email_required? false end 修改user migration文件,给phone ...

  4. ACM ICPC, Amman Collegiate Programming Contest (2018) Solution

    Solution A:Careful Thief 题意:给出n个区间,每个区间的每个位置的权值都是v,然后找长度为k的区间,使得这个区间的所有位置的权值加起来最大,输出最大权值, 所有区间不重叠 思路 ...

  5. Java 动态代理是基于什么原理

    动态代理 ①动态代理概念理解 动态代理是一种方便运行时动态构建代理.动态处理代理方法调用的机制,很多场景都利用类似机制做到的,比如用来包装RPC调用.面向切面的变成(AOP) 实现动态代理的方式很多, ...

  6. Linux 查看系统所有用户

    grep bash /etc/passwd Linux 查看系统所有用户

  7. [one day one question] webpack 打包报错 Cannot assign to read only property 'exports' of object '#<Object>'

    问题描述: webpack 打包报错 Cannot assign to read only property 'exports' of object '#<Object>',这怎么破? 解 ...

  8. MFC读写EXIF信息,图片非占用

    MFC读写EXIF信息 读取有类库可以直接调用,网络上有直接可以用的:但是写Exif的资料非常少,我花了一点时间研究收集,终于成功. 将相关的资料共享.主要是借助gdi+,需要注意的地方很多   // ...

  9. 获取当前线程id

    转:https://www.cnblogs.com/comsky/p/6020327.html 如果获得当前进程的Id用: Process[] processes = Process.GetProce ...

  10. 学习Zookeeper之第3章Zookeeper内部原理

    第 3 章 Zookeeper 内部原理 3.1 选举机制 3.2 节点类型 3.3 stat 结构体 3.4 监听器原理   1)监听原理详解   2)常见的监听 3.5 写数据流程 第 3 章 Z ...