1、功能描述
- Linux系统中的 route 命令能够用于IP路由表的显示和操作。它的主要作用是创建一个静态路由让指定一个主机或者一个网络通过一个网络接口,如 ens33。当使用 "add" 或者 "del" 参数时,路由表被修改,如果没有参数,则显示路由表当前的内容。在一个网络中,需要一个路由器来转发不同广播域之间的数据,或是转发 lan 和 internet 之间的数据。有时我们需要设定这个路由器作为 linux系 统的默认路由,那么就可以通过 route 命令来操作。甚至我们也可以用我们的linux系统来充当路由器
- 要注意的是,直接在命令行下执行route命令来添加路由,不会永久保存,当网卡重启或者机器重启之后,该路由就失效了;可以在 /etc/rc.local中 添加 route 命令来保证该路由设置永久有效。当然如果加上了 -p 参数的话那就会永久的生效了
2、命令格式
route [-f] [-p] [Command [Destination] [mask Netmask] [Gateway][metric Metric]] [if Interface]]
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)、显示路由
[root@kvm111 ~]# 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.2.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33
说明
- U Up,表示此路由当前为启动状态
- H Host,表示此网关为一主机
- G Gateway,表示此网关为一路由器
- R Reinstate Route,使用动态路由重新初始化的路由
- D Dynamically,此路由是动态性地写入
- M Modified,此路由是由路由守护程序或导向器动态修改
(2)、添加指向某个网络的路由
[root@kvm111 ~]# route add -net 10.3.1.0 netmask 255.255.255.0 dev ens33
[root@kvm111 ~]# route
# 成功
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
default gateway 0.0.0.0 UG 100 0 0 ens33
10.3.1.0 0.0.0.0 255.255.255.0 U 0 0 0 ens33
192.168.2.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33
(3)、添加指向某个IP的路由
[root@kvm111 ~]# route add -host 192.168.2.200 dev ens33
[root@kvm111 ~]# route
# 默认是会帮我们添加一个全255的子网掩码
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
default gateway 0.0.0.0 UG 100 0 0 ens33
10.3.1.0 0.0.0.0 255.255.255.0 U 0 0 0 ens33
192.168.2.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33
192.168.2.200 0.0.0.0 255.255.255.255 UH 0 0 0 ens33
(4)、添加一个默认网关
# 这里我的虚拟机是2个网卡,一个NAT,一个Bridge
[root@kvm111 ~]# route add default gw 192.168.1.1
[root@kvm111 ~]# route
# 成功
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
default gateway 0.0.0.0 UG 0 0 0 ens37
default gateway 0.0.0.0 UG 100 0 0 ens33
192.168.1.0 0.0.0.0 255.255.255.0 U 101 0 0 ens37
192.168.2.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33
(5)、删除一个默认网关
[root@kvm111 ~]# route del default gw 192.168.1.1
[root@kvm111 ~]# 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.1.0 0.0.0.0 255.255.255.0 U 101 0 0 ens37
192.168.2.0 0.0.0.0 255.255.255.0 U 100 0 0 ens33