Linux系统的route
命令用于显示和操作IP路由表(show / manipulate the IP routing table)。要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现。在Linux系统中,设置路由通常是为了解决以下问题:该Linux系统在一个局域网中,局域网中有一个网关,能够让机器访问Internet,那么就需要将这台机器的IP地址设置为Linux机器的默认路由。要注意的是,直接在命令行下执行route命令来添加路由,不会永久保存,当网卡重启或者机器重启之后,该路由就失效了;可以在/etc/rc.local
中添加route
命令来保证该路由设置永久有效。
route [-f] [-p] [Command [Destination] [mask Netmask] [Gateway] [metric Metric]] [if Interface]]
route
命令是用于操作基于内核ip路由表,它的主要作用是创建一个静态路由让指定一个主机或者一个网络通过一个网络接口,如eth0
。当使用”add
“或者”del
“参数时,路由表被修改,如果没有参数,则显示路由表当前的内容。
-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
命令的显示功能。可以使用十进制或十六进制值进行接口索引。命令:
route route -n
输出:
[zyiz@localhost ~]$ route Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface default gateway 0.0.0.0 UG 100 0 0 ens33 192.168.0.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33 [zyiz@localhost ~]$ route -n Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 0.0.0.0 192.168.0.1 0.0.0.0 UG 100 0 0 ens33 192.168.0.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33 [zyiz@localhost ~]$
说明:
第一行表示主机所在网络的地址为192.168.0.197
,若数据传送目标是在本局域网内通信,则可直接通过ens33
转发数据包;
第四行表示数据传送目的是访问 Internet,则由接口ens33
,将数据包发送到网关192.168.0.1
其中Flags
为路由标志,标记当前网络节点的状态。
Flags标志说明:
U
Up表示此路由当前为启动状态H
Host,表示此网关为一主机G
Gateway,表示此网关为一路由器R
Reinstate Route,使用动态路由重新初始化的路由D
Dynamically,此路由是动态性地写入M
Modified,此路由是由路由守护程序或导向器动态修改!
表示此路由当前为关闭状态备注:route -n
(-n
表示不解析名字,列出速度会比 route
快)
命令:
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.0.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.0.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.0.240 0.0.0.0 UG 0 0 0 eth0
说明:增加一条 到达244.0.0.0
的路由
命令:
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.0.0 * 255.255.255.0 U 0 0 0 eth0 192.168.0.0 192.168.0.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.0.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.0.240 0.0.0.0 UG 0 0 0 eth0
说明:增加一条屏蔽的路由,目的地址为 224.x.x.x 将被拒绝
命令:
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.0.0 * 255.255.255.0 U 0 0 0 eth0 192.168.0.0 192.168.0.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.0.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.0.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.0.0 * 255.255.255.0 U 0 0 0 eth0 192.168.0.0 192.168.0.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.0.1 255.0.0.0 UG 0 0 0 eth0 224.0.0.0 - 240.0.0.0 ! 0 - 0 - default 192.168.0.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.0.0 * 255.255.255.0 U 0 0 0 eth0 192.168.0.0 192.168.0.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.0.1 255.0.0.0 UG 0 0 0 eth0 default 192.168.0.240 0.0.0.0 UG 0 0 0 eth0 [root@localhost ~]#
命令:
route del default gw 192.168.0.240 route add default gw 192.168.0.240
输出:
[root@localhost ~]# route del default gw 192.168.1.240 [root@localhost ~]# route Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.1.0 * 255.255.255.0 U 0 0 0 eth0 192.168.0.0 192.168.1.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.1.1 255.0.0.0 UG 0 0 0 eth0 [root@localhost ~]# route add default gw 192.168.1.240 [root@localhost ~]# route Kernel IP routing table Destination Gateway Genmask Flags Metric Ref Use Iface 192.168.1.0 * 255.255.255.0 U 0 0 0 eth0 192.168.1.0 192.168.1.1 255.255.0.0 UG 0 0 0 eth0 10.0.0.0 192.168.1.1 255.0.0.0 UG 0 0 0 eth0 default 192.168.1.240 0.0.0.0 UG 0 0 0 eth0 [root@localhost ~]#