Linux学习之route

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 [[email protected] ~]# 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 [[email protected] ~]# 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 [[email protected] ~]# route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0
2 [[email protected] ~]# 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

[[email protected] ~]#

说明:

增加一条 到达244.0.0.0的路由

实例3:屏蔽一条路由

命令:

route add -net 224.0.0.0 netmask 240.0.0.0 reject

输出:

[[email protected] ~]# route add -net 224.0.0.0 netmask 240.0.0.0 reject
[[email protected] ~]# 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

说明:

增加一条屏蔽的路由,目的地址为 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 [[email protected] ~]# 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 [[email protected] ~]# route del -net 224.0.0.0 netmask 240.0.0.0
11 [[email protected] ~]# 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 [[email protected] ~]# route del -net 224.0.0.0 netmask 240.0.0.0 reject
20 [[email protected] ~]# 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 [[email protected] ~]#

说明:

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

命令:

route del default gw 192.168.120.240

route add default gw 192.168.120.240

输出:

 1 [[email protected] ~]# route del default gw 192.168.120.240
 2 [[email protected] ~]# 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 [[email protected] ~]# route add default gw 192.168.120.240
 9 [[email protected] ~]# 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 [[email protected] ~]#
时间: 2024-10-26 03:41:48

Linux学习之route的相关文章

linux学习笔记31--命令route

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

(转)Linux学习要点(转载自红联)

Linux学习要点(转载自红联) 一.学习Linux的基本要求1. 掌握至少50个以上的常用命令. 2. 熟悉Gnome/KDE等X-windows桌面环境操作 . 3. 掌握.tgz..rpm等软件包的常用安装方法 4. 学习添加外设,安装设备驱动程序(比如网卡) 5. 熟悉Grub/Lilo引导器及简单的修复操作 . 6. 熟悉Linux文件系统 和目录结构. 7. 掌握vi,gcc,gdb等常用编辑器,编译器,调试器 . 8. 理解shell别名.管道.I/O重定向.输入和输出以及shel

linux学习之路之LVM

试想一种情况,当初我们在规划磁盘的时候,只给某一个磁盘或分区之划分了30G的容量,但是后来,随着业务的需求,该磁盘或者分区的使用量会越来越大,等到以后再有数据存放时,发现该磁盘或者分区的容量不够用,此时该怎么办了?可以新增一个磁盘,经过格式化,挂载等过程就可以使用这个磁盘了,再将原来磁盘的数据完全的复制过来.等到后来又发现,规划的磁盘又太大了,然后又使用上述方法来减少磁盘的大小.虽然这种方法可行,但是效率低,比较复杂.不应该是我们首选的方法. 当然,我们可以这样做,将多个磁盘或者分区(PV)组合

Linux学习日志2-vim使用基础

vim是linux操作系统下的一个文本编辑工具,功能非常强大,但刚学习起来比较复杂.vim的所有功能要讲明白得有几百页,在这里只是记录一下vim的一些基本用法. 首先vim打开文件的三种方式: vim +# xxx(#是数字):表示打开xxx文件并将光标定位到指定行. vim -o xx1 xx2 xx3:表示同时打开三个文件,垂直分割显示 vim -O xx1 xx2 xx3:表示同时打开三个文件,水平分割显示 多个文件间跳转:键入ctrl+w后:→向左.←向右.↑向上.↓向下 vim打开文件

                        linux     学习  

决心书 我叫孙启浩,出生在山东淄博的一个农村.15岁初中还没有毕业,就去上了技校,其实父母是想让我提早的步入社会,我在那个地方学的是'电厂热能动力装置' 本来我是想学it的可是我父母说就学这个因为在我们那里电厂找工作也好找工资肯定比学it工资要高,我就这样在那个对我来说无所谓的学校学了两年半.放暑假的时候我哥回来说要进京学it,我就想要不我也去学?因为我对这个it还是挺感兴趣的,之后就来了北京,先去看了一个学校叫'八维'觉得这个学校不怎么好,上来先学单词什么的我这种人一看书就想睡觉.然后我父亲的

linux学习笔记(一)-文件目录相关的命令&&文件通配符

一.几个命令概述 1.查看目录以及目录底下的文件:ls(-a显示隐藏文件:-d显示目录本身:-l显示详细内容:-R递归显示,即把子目录的文件也显示出来:-h以更加被人类理解的格式显示,比如显示文件大小的时候用M为单位显示:-i显示文件索引ID) 2.查看文件内容:cat,head,tail,less,more,tac cat:将文件连接起来,输出在屏幕上,可接多个文件(-E:显示隐藏的换行符:-n:显示出行号) head:默认查看文件的前10行(-n#:查看文件的前#行.空白行也是一行) tai

Linux学习日志day1——无人值守系统安装DHCP+TFTP+PXE+Kickstar

Linux学习日志day1--无人值守批量系统远程网络安装(DHCP+TFTP+PXE+Kickstar)                                         --作者:江信瀚 服务器环境介绍: 主机名:workstation.example.com 关闭SElinux以及防火墙 虚拟机:VMware(关闭了VMware的DHCP服务) 网卡配置: 静态IP获取! IPV6全部都删除,因为根本用不到 子网IP可以在VMware中设置 8.8.8.8是谷歌的DNS服务器

linux学习-练习1

touch 创建多目录 ls查看当前目录下的所有隐藏文件 ls查看/boot目录下面的所有目录 帮助的使用 内部命令 用 help command   或  man bash 外部命令 用 command --help 或  command -h 使用手册 man 信息页 info date命令: 显示昨天 : date -d yesterday 显示前天 : date -d '-2 day' 显示当天 :  date -d '0 day' +%F 显示当前日期,格式:2016-08-08 显示

51CTO学院三周年,我的linux学习思想分享

51CTO学院三周年了,我也关注学院三周年了,在51CTO的平台上,让我学到了很多的东西,也交到了很多朋友,每当你发一篇博文,总会有些志同道合的小伙伴们去点赞,甚至还会有大神高手,去指出你分享内容里面的不足.在和这些虚拟的未曾相识的朋友们的交流中我的技术得到了提高,时光荏苒,一晃都三年了. 首先我要感谢51CTO做的一个关于技术的分享平台,经过大家的分享,里面的博客已经非常丰富了,很多优秀的文章可以供我们去学习和分享.我是一名运维工程师,从事运维工作已经3年多了,每天上班的第一件事情就是登上我的