route命令

  可以显示或管理Linux系统的路由表,route命令设置的路由主要是静态路由。

路由的概念

    计算机与计算机之间的数据传输必须得经由网络,而网络可以通过直接连接两台计算机的方式或者是以一个或一个以上的节点来构成。
    数据传输首先会通过源主机传送到一个网络节点,然后这个网络节点会根据“约定”将数据传送到另一个网络节点,另一个网络节点再将数据传输到下一个节点,依此类推,最终把数据传输到目标主机。
    这就是数据传送的一个完整过程,而每个网络节点就是一个路由,“约定”就是路由规则,数据传输就是根据路由规则依次传输下去的。

路由的分类

    路由分为静态路由和动态路由。
    Linux上配置的路由都属于静态路由。静态路由规则是系统管理员使用route命令加入的,也就是通过手动输入的方式来加入的路由规则。
    动态路由就是无需手动输入路由的规则,其路由规则是本机与不同的机器彼此经过路由程序(Routing daemon)相互交换路由规则而来的。

route命令的参数选项及说明

 
-n    直接使用IP地址,不进行DNS解析主机名
-ee   显示更详细的路由信息
add    添加路由信息
del    删除路由信息
target    指定目标网络或主机。可以用IP地址或主机/网络名
-net    到一个网络的路由,后面接的是一个网络号地址
-host    到一个主机的路由,后面接的是一个主机地址
netmask NM    为添加的路由指定网络掩码
gw Gw         为发往目标网络/主机的任何分组指定网关
dev If        指定由哪个网络设备出去,后面接网络设备名,如eth0等
 

查看当前系统路由表信息

[root@bzhl ~]# route    #<=默认情况下,route命令会将IP地址进行DNS解析生成主机名。
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
default gateway 0.0.0.0 UG 100 0 0 eth0
213.232.105.0 0.0.0.0 255.255.255.0 U 100 0 0 eth0
[root@bzhl ~]# route -n
Kernel IP routing table #<=使用-n选项不进行DNS解析,这样会加快显示速度。
Destination Gateway Genmask Flags Metric Ref Use Iface
0.0.0.0 213.232.105.1 0.0.0.0 UG 100 0 0 eth0
213.232.105.0 0.0.0.0 255.255.255.0 U 100 0 0 eth0
命令结果说明具体如下。
Destination:表示网络号,也就是network的意思。
Gateway:连出网关地址,也就是说该网络是通过该IP连接出去的,如果显示0.0.0.0,则表示该路由是直接由本机传送出的。如果有IP显示,则表示本条路由必须经过该IP的转接才能连接出去。
Genmask:表示子网掩码地址,也就是netmask。Destination和Genmask将组合成一个完整的网络。
Flags:路由标记信息,通常会有下面几种不同的标记。
U(route is up):表示此路由当前为启动状态。
H(target is a host):目标路由是一个主机(IP)而非网络。
R(reinstate route for dynamic routing):使用动态路由时,恢复路由信息标识。
G(use gateway):表示需要通过外部的主机(gateway)来转接传递数据。
M(modified from routing daemon or redirect):表示路由已经被修改了。
D(dynamically installed by daemon or redirect):已经由服务设定为动态路由。
!(reject route):这个路由将不会被接受(用来抵挡不安全的网络)。
Metric:需要经过几个网络节点(hops)才能到达路由的目标网络地址。
Ref:参考到此路由规则的数目。
Use;有几个转送数据包参考到了此路由规则。
Iface:路由对应的网络设备接。
 
    命令输出结果的第一行(10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 etho)表示主机所在的网段为10.0.0.0,若数据传送目标是在同一网段,则可直接通过eth0转发数据包。
    命令输出结果的第三行(0.0.0.0 10.0.0.2 0.0.0.0 UG 0 0 0 eth0)是系统的默认网关信息,表示去任何地方(0.0.0.0)都发给10.0.0.2,因为是默认网关,所以放在了最后一条。路由也是有顺序的,如果不符合任何一条规则就交给默认网关来处理。
 

删除和添加默认网关

    默认网关就是数据包不匹配任何设定的路由规则最后流经的地址关口!网关按字面意思就是网络的关口,相当于我们家里房子的门一样,如果外出就要经过房门,数据包也是一样。下面来看一下删除和添加默认网关的方法:

方法1

[root@cs6 ~]# route del default <-删除网关方法1。
[root@cs6 ~]# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0
#<==第3行的网关已经删除。 [root@cs6 ~]# ping g.cn
connect: 网络不可达 [root@cs6 ~]# route add default gw 10.0.0.2 #<=添加网关方法主:需要指明网关地址10.0.0,2或其他正确的地址。
[root@cs6 ~]# ping g.cn
PING g.cn (203.208.40.87) 56(84) bytes of data.
64 bytes from 203.208.40.87: icmp_seq=1 ttl=128 time=44.9 ms
64 bytes from 203.208.40.87: icmp_seq=2 ttl=128 time=42.6 ms
^C
--- g.cn ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1706ms
rtt min/avg/max/mdev = 42.613/43.784/44.956/1.190 ms [root@cs6 ~]# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0
0.0.0.0 10.0.0.2 0.0.0.0 UG 0 0 0 eth0

方法2

[root@cs6 ~]# route del default gw 10.0.0.2
[root@cs6 ~]# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0
[root@cs6 ~]# route add default gw 10.0.0.2 dev eth0 #<=添加网关方法2,使用dev指明网络设备,连用于有多块网络设备的主机。
[root@cs6 ~]# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0
0.0.0.0 10.0.0.2 0.0.0.0 UG 0 0 0 eth0 #特别强调:实际上 route add default gw 10.0.0.2 就相当于
route add -net 0.0.0.0 netmask 0.0.0.0 gw 10.0.0.2

配置网络路由(去往某一网络或网段的路由)

    一般多网段之间互相通信,会希望建立一条优先路由,而不是通过默认网关,这时就可以配置网络路由。还是拿房子作比喻,你现在不是要出门,而是要去卧室或卫生间,去卧室就要经过卧室的门,去卫生间就要经过卫生间的门,这里的卧室和卫生间的门就可以认为是去往某一网段的路由,而不是默认路由(即房子的大门)。    
    在实际工作中也会有类似的需求,即两个不同的内部网络之间互相访问,而不是出网访问。
 
    有两个网段10.0.0.0/24和192.168.1.0/24,现在想要实现10网段的机器访问192网段的机器,其中有一台机器有两块网卡,eth0 的IP地址为192.168.1.254,eth1 的IP地址为10.0.0.254。那么配置网络路由会有以下几种方法。
 
 
方法1
route add -net 192.168.1.0/24 gw 10.0.0.254
方法2
route add -net 192.168.1.0 netmask 255.255.255.0 dev eth1 #<=指定设备而不是地址。
route add -net 192.168.1.0/24 dev eth1
 
    在想要访问192网段的每台10网段的机器上执行上面的命令,那么就只是执行该命令的主机能够访问192网段;但若在10网段的网关10.0.0.2上执行上面的命令,则10网段的机器都能访问192网段。

删除网络路由

route del -net 192.168.1.0/24 dev eth1
 
以上配置在重启网络时都会失效,如果希望永久生效,则有如下几种方法。
 
方法1:
    vi /etc/sysconfig/network-scripts/route-eth1    #<=默认不存在此文件
加入如下内容:
    192.168.1.0/24 via 10.0.0.254
 
写到配置里,重启网络服务和重启系统都会生效!
 
方法2:
  vi /etc/sysconfig/static-routes    #<=默认不存在此文件
加入如下内容:
  any net 192.168.1.0/24 gw 10.0.0.254
 
 
方法3:
  vi /etc/rc.local 
加入如下内容:
 route add -net 192.168.1.0/24 gw 10.0.0.254
 
提示:方法1推荐在生产环境下使用,方法3写到/etc/rc.local里只在开机时加载,在手工重启网络后会失效,但是重启系统后会生效!
[root@cs6 ~]# route add -net 192.168.205.0/24 dev eth0
[root@cs6 ~]# route -n
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
10.0.0.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
192.168.205.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
169.254.0.0 0.0.0.0 255.255.0.0 U 1002 0 0 eth0
0.0.0.0 10.0.0.2 0.0.0.0 UG 0 0 0 eth0 如果是配置默认路由网关,则可以写在网卡配置里,代码如下:
[root@cs6 ~]# grep GATEWAY /etc/sysconfig/network-scripts/ifcfg-eth0
GATEWAY=10.0.0.2

配置和删除主机路由(就是去往某个主机地址的路由)

route add -host 192.169.2.18 dev eth2
route add -host 202.81.11.9 dev lo
 
例如:keepalived或heartbeat高可用服务器对之间使用单独的网卡接心跳线通信时,就会用到以上的主机路由。删除主机路由的方法如下:
route del -host 192.168.2.13 dev eth2
 
 
 

10.4 route:显示或管理路由表的更多相关文章

  1. Linux命令之route - 显示和操作IP路由表

    转自:  http://codingstandards.iteye.com/blog/1125312 用途说明 route命令用于显示和操作IP路由表(show / manipulate the IP ...

  2. Spring MVC 学习笔记10 —— 实现简单的用户管理(4.3)用户登录显示全局异常信息

    </pre>Spring MVC 学习笔记10 -- 实现简单的用户管理(4.3)用户登录--显示全局异常信息<p></p><p></p>& ...

  3. RDIFramework.NET ━ 9.10 岗位(职位)管理 ━ Web部分

    RDIFramework.NET ━ .NET快速信息化系统开发框架 9.10  岗位(职位)管理 -Web部分 岗位(职位)管理模块主要是针对组织机构的岗位(职位)进行管理,包括:增加.修改.删除. ...

  4. 实验10.3_数值显示拓展_dword型数转变为表示十进制数的字符串

    assume cs:code data segment db 10 dup (0) data ends code segment start : mov ax,4240H;F4240H=1000000 ...

  5. Linux 命令 - route: 显示或操作路由表

    route 命令查看路由表或者手动地添加.删除和修改路由表中的条目. 命令格式 route [-CFvnNee] [-A family] route [-v] [-A family] add [-ne ...

  6. django1.10.3下admin后台管理老是显示object

    在设置了一个新models phone book后,admin管理显示数据名称都是object 尝试为model重写__unicode__方法后无效,经查询,在py3环境中,需要重写__str__方法 ...

  7. Android核心分析之二十四Android GDI之显示缓冲管理

    Android GDI之屏幕设备管理-动态链接库 万丈高楼从地起,从最根源的硬件帧缓冲区开始.我们知道显示FrameBuffer在系统中就是一段内存,GDI的工作就是把需要输出的内容放入到该段内存的某 ...

  8. route - 显示 / 操作IP选路表

    总览 SYNOPSIS route [-CFvnee] route [-v] [-A family] add [-net|-host] target [netmask Nm] [gw Gw] [met ...

  9. 基于Metronic的Bootstrap开发框架经验总结(10)--优化Bootstrap图标管理

    在基于Bootstrap开发的项目中,鲜艳颜色的按钮,以及丰富的图表是很吸引人的特点,为了将这个特点发挥到极致,可以利用Bootstrap图标抽取到数据库里面,并在界面中进行管理和使用,这样我们可以把 ...

随机推荐

  1. [源码分析] 分布式任务队列 Celery 之 发送Task & AMQP

    [源码分析] 分布式任务队列 Celery 之 发送Task & AMQP 目录 [源码分析] 分布式任务队列 Celery 之 发送Task & AMQP 0x00 摘要 0x01 ...

  2. Linux保护机制和绕过方式

    Linux保护机制和绕过方式 CANNARY(栈保护) ​ 栈溢出保护是一种缓冲区溢出攻击缓解手段,当函数存在缓冲区溢出攻击漏洞时,攻击者可以覆盖栈上的返回地址来让shellcode能够得到执行.用C ...

  3. buuctf --pwn part2

    pwn难啊! 1.[OGeek2019]babyrop 先check一下文件,开启了NX 在ida中没有找到system.'/bin/sh'等相关的字符,或许需要ROP绕过(废话,题目提示了) 查看到 ...

  4. Day01_08_变量(Variable)

    变量 什么是变量? *变量本质上来说是内存上的一块空间,这块空间有数据类型,有名字,有字面值(数据).变量是内存中存储数据最基本的单元 * 变量要求变量中存储的具体数据必须和变量的数据类型一致,必须先 ...

  5. 数据结构之队列(JavaScript描述)

    队列数据结构   队列遵循先进先出原则的一组有序的项.对可在尾部添加新元素并从顶部移除元素.最新添加的元素必须排在队列的末尾 队列类似栈的例子 创建队列 创建一个类表示队列 队列内应该有一些方法 添加 ...

  6. 这种ERP系统核查工作实际是在做无用功

    前段时间跟朋友聊起他们公司持续了好几年的ERP核查工作,此时他正在一家分公司做核查.ERP核查工作我是知道的,一个季度一次,每个模块出一个人去子公司巡回巡查,主要核查ERP系统的使用情况. 核查工作主 ...

  7. [源码分析]并行分布式任务队列 Celery 之 子进程处理消息

    [源码分析]并行分布式任务队列 Celery 之 子进程处理消息 0x00 摘要 Celery是一个简单.灵活且可靠的,处理大量消息的分布式系统,专注于实时处理的异步任务队列,同时也支持任务调度.在前 ...

  8. 浅谈在c#中使用Zlib压缩与解压的方法

    作者:Compasslg 介绍 近期用c#开发一个游戏的存档编辑工具需要用 Zlib 标准的 Deflate 算法对数据进行解压. 在 StackOverflow 上逛了一圈,发现 c# 比较常用到的 ...

  9. 1.1.09- 序列赋值 is , is not运算符

    两个变量的交换算法 代码如下: a = 10000 b = 20000 temp = a a = b b = temp print(a) print(b) 序列赋值: a,b = b,aprint(a ...

  10. 07- Linux常用命令

    cat命令 作用:将文件内容作为标准输出打印到终端. 格式:cat   文件名1  文件名2 例如: cat more命令: 作用:分页显示文本文件的内容 格式:more 文件名 实例:more he ...