Linux下路由配置梳理(转)
转自:https://www.cnblogs.com/kevingrace/p/6490627.html
在日常运维作业中,经常会碰到路由表的操作。下面就linux运维中的路由操作做一梳理:
------------------------------------------------------------------------------
先说一些关于路由的基础知识:
1)路由概念
路由: 跨越从源主机到目标主机的一个互联网络来转发数据包的过程
路由器:能够将数据包转发到正确的目的地,并在转发过程中选择最佳路径的设备
路由表:在路由器中维护的路由条目,路由器根据路由表做路径选择
直连路由:当在路由器上配置了接口的IP地址,并且接口状态为up的时候,路由表中就出现直连路由项
静态路由:是由管理员手工配置的,是单向的。
默认路由:当路由器在路由表中找不到目标网络的路由条目时,路由器把请求转发到默认路由接口 。
2)静态路由和默认路由的特点
静态路由特点:
路由表是手工设置的;
除非网络管理员干预,否则静态路由不会发生变化;
路由表的形成不需要占用网络资源;
适用环境:一般用于网络规模很小、拓扑结构固定的网络中。
默认路由特点:
在所有路由类型中,默认路由的优先级最低
适用环境:一般应用在只有一个出口的末端网络中或作为其他路由的补充
浮动静态路由:
路由表中存在相同目标网络的路由条目时,根据路由条目优先级的高低,将请求转发到相应端口;
链路冗余的作用;
3)路由器转发数据包时的封装过程
源IP和目标IP不发生变化,在网络的每一段传输时,源和目标MAC发生变化,进行重新封装,分别是每一段的源和目标地址
4)要完成对数据包的路由,一个路由器必须至少了解以下内容:
a)目的地址
b)相连路由器,并可以从哪里获得远程网络的信息
c)到所有远程网络的可能路由
d)到达每个远程网络的最佳路由
e)如何维护并验证路由信息
f)路由和交换的对比
路由工作在网络层
a)根据“路由表”转发数据
b)路由选择
c)路由转发
交换工作在数据链路层
d)根据“MAC地址表”转发数据
e)硬件转发
------------------------------------------------------------------------------
接着说下linux运维中关于路由的一些操作
1)使用route -n命令查看Linux内核路由表
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
[root@dev ~]# route -nKernel IP routing tableDestination Gateway Genmask Flags Metric Ref Use Iface192.168.1.17 0.0.0.0 255.255.255.255 UH 0 0 0 ppp010.1.32.14 0.0.0.0 255.255.255.255 UH 0 0 0 tun010.1.32.12 0.0.0.0 255.255.255.255 UH 0 0 0 tun010.4.8.2 192.168.9.254 255.255.255.255 UGH 0 0 0 eth010.4.9.0 0.0.0.0 255.255.255.0 U 0 0 0 tun0192.168.9.0 0.0.0.0 255.255.255.0 U 1 0 0 eth010.2.0.0 0.0.0.0 255.255.0.0 U 0 0 0 tun010.0.0.0 0.0.0.0 255.255.0.0 U 0 0 0 tun010.1.0.0 0.0.0.0 255.255.0.0 U 0 0 0 tun0192.168.0.0 0.0.0.0 255.255.0.0 U 0 0 0 tun00.0.0.0 192.168.9.254 0.0.0.0 UG 0 0 0 eth0 |

2)三种路由类型说明
a)主机路由
主机路由是路由选择表中指向单个IP地址或主机名的路由记录。主机路由的Flags字段为H。例如,在下面的示例中,本地主机通过IP地址192.168.1.1的路由器到达IP地址为10.0.0.10的主机。
|
1
2
3
|
Destination Gateway Genmask Flags Metric Ref Use Iface----------- ------- ------- ----- ------ --- --- -----10.0.0.10 192.168.1.1 255.255.255.255 UH 0 0 0 eth0 |
b)网络路由
网络路由是代表主机可以到达的网络。网络路由的Flags字段为N。例如,在下面的示例中,本地主机将发送到网络192.19.12的数据包转发到IP地址为192.168.1.1的路由器。
|
1
2
3
|
Destination Gateway Genmask Flags Metric Ref Use Iface----------- ------- ------- ----- ----- --- --- -----192.19.12 192.168.1.1 255.255.255.0 UN 0 0 0 eth0 |
c)默认路由
当主机不能在路由表中查找到目标主机的IP地址或网络路由时,数据包就被发送到默认路由(默认网关)上。默认路由的Flags字段为G。例如,在下面的示例中,默认路由是IP地址为192.168.1.1的路由器。
|
1
2
3
|
Destination Gateway Genmask Flags Metric Ref Use Iface----------- ------- ------- ----- ------ --- --- -----default 192.168.1.1 0.0.0.0 UG 0 0 0 eth0 |
3)配置路由route的命令
设置和查看路由表都可以用 route 命令,设置内核路由表的命令格式是:
|
1
|
route [add|del] [-net|-host] target [netmask Nm] [gw Gw] [[dev] If] |
参数解释:
add 添加一条路由规则
del 删除一条路由规则
-net 目的地址是一个网络
-host 目的地址是一个主机
target 目的网络或主机
netmask 目的地址的网络掩码
gw 路由数据包通过的网关
dev 为路由指定的网络接口
4)route命令使用举例
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
添加到主机的路由# route add -host 192.168.1.2 dev eth0:0# route add -host 10.20.30.148 gw 10.20.30.40 添加到网络的路由# route add -net 10.20.30.40 netmask 255.255.255.248 eth0# route add -net 10.20.30.48 netmask 255.255.255.248 gw 10.20.30.41# route add -net 192.168.1.0/24 eth1 添加默认路由# route add default gw 192.168.1.1 删除路由# route del -host 192.168.1.2 dev eth0:0# route del -host 10.20.30.148 gw 10.20.30.40# route del -net 10.20.30.40 netmask 255.255.255.248 eth0# route del -net 10.20.30.48 netmask 255.255.255.248 gw 10.20.30.41# route del -net 192.168.1.0/24 eth1# route del default gw 192.168.1.1 //route del default 删除所有的默认路由添加一条默认路由# route add default gw 10.0.0.1 //默认只在内存中生效开机自启动可以追加到/etc/rc.local文件里# echo "route add default gw 10.0.0.1" >>/etc/rc.local添加一条静态路由# route add -net 192.168.2.0/24 gw 192.168.2.254要永久生效的话要这样做:# echo "any net 192.168.2.0/24 gw 192.168.2.254" >>/etc/sysconfig/static-routes添加到一台主机的静态路由# route add -host 192.168.2.2 gw 192.168.2.254要永久生效的话要这样做:# echo "any host 192.168.2.2 gw 192.168.2.254 " >>/etc/sysconfig/static-routes注:Linux 默认没有这个文件 ,得手动创建一个 |
5)设置包转发
在Linux中默认的内核配置已经包含了路由功能,但默认并没有在系统启动时启用此功能;
开启Linux的路由功能可以通过调整内核的网络参数来实现,方法如下:
|
1
2
3
4
5
6
7
8
|
临时开启路由功能:# echo 1 > /proc/sys/net/ipv4/ip_forward或者# sysctl -w net.ipv4.ip_forward=1 永久开启路由功能 # vim /etc/sysctl.confnet.ipv4.ip_forward = 1# sysctl -p |
6)静态路由配置
添加静态路由到路由表的语法如下:
|
1
|
ip route [destination_network] [mask] [next-hop_address] administrative_distance] |
参数解析:
ip route 用于创建静态路由的命令。
Destination_network 需要发布到路由表中的网段。
Mask 在这一网络上使用的子网掩码。
Next-hop_address 下一跳路由器的地址。
administrative_distance 默认时,静态路由有一个取值为1 的管理性距离。在这个命令的尾部添加管理权来修改这个默认值。
例如
|
1
|
ip route 172.16.1.0 255.255.255.0 172.16.2.1 |
查看路由表除了使用route -n命令外,还可以使用ip route
|
1
2
3
4
5
6
7
8
9
10
11
12
|
[root@dev ~]# ip route192.168.1.17 dev ppp0 proto kernel scope link src 192.168.1.190 10.1.32.14 dev tun0 scope link 10.1.32.12 dev tun0 scope link 10.4.8.2 via 192.168.9.254 dev eth0 src 192.168.9.200 mtu 1500 advmss 146010.4.9.0/24 dev tun0 scope link 192.168.9.0/24 dev eth0 proto kernel scope link src 192.168.9.200 metric 1 10.2.0.0/16 dev tun0 scope link 10.0.0.0/16 dev tun0 scope link 10.1.0.0/16 dev tun0 scope link 192.168.0.0/16 dev tun0 scope link default via 192.168.9.254 dev eth0 |
----------------------------------------实例1--------------------------------------------

如上图所示,PC0机器和PC1机器之间经过两个路由器,要想使这两台机器通信,路由设置如下:
1)Route0路由器设置:
|
1
2
3
|
ip add 192.168.1.1 255.255.255.0ip add 192.168.2.1 255.255.255.0ip route 192.168.3.0 255.255.255.0 192.168.2.2 |
2)Route1路由器设置:
|
1
2
3
|
ip add 192.168.2.2 255.255.255.0ip add 192.168.3.1 255.255.255.0ip route 192.168.1.0 255.255.255.0 192.168.2.1 |
----------------------------------------实例2--------------------------------------------

如上图所示,使用A主机192.168.1.2能够ping通E主机192.168.4.2,这两台机能够通信。
操作思路:
1)在主机B上设置默认路由下一跳为192.168.2.2,并开启路由转发功能;
2)在主机C上设置2条静态路由,分别去192.168.1.0/24网段的下一跳为192.168.2.1,去192.168.4.0/24网段的下一跳为192.168.3.2,并开启路由转发功能;
3)在主机D上设置默认路由下一跳为192.168.3.1,并开启路由转发功能。
操作记录:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
1)A主机上操作:ip为192.168.1.2,设置网关为192.168.1.1# route add default gw 192.168.1.12)B主机上操作:第一块网卡为192.168.1.1,第二块网卡为192.168.2.1# ifconfig eth0 192.168.1.1# ifconfig eth1 192.168.2.1 //可以在一块网卡上设置两个ip,比如是eth0,eth0:0B主机设置默认路由,下一跳为192.168.2.2# route add default gw 192.168.2.2B主机开启路由转发功能# echo 1 > /proc/sys/net/ipv4/ip_forward //临时转发,可以在/etc/sysctl.conf里设置永久转发3)C主机上操作:第一块网卡为192.168.2.2,第二块网卡为192.168.3.1# ifconfig eth0 192.168.2.2# ifconfig eth1 192.168.3.1 //如果就一块网卡,可以设置ifconfig eth0:0 192.168.3.1C主机设置2条默认路由# route add -net 192.168.1.0/24 gw 192.168.2.1# route add -net 192.168.4.0/24 gw 192.168.3.2C主机开启路由转发功能# echo 1 > /proc/sys/net/ipv4/ip_forward4)D主机上操作:第一块网卡为192.168.3.2,第二块网卡为192.168.4.1# ifconfig eth0 192.168.3.2# ifconfig eth1 192.168.4.1D主机设置默认路由,下一跳为192.168.3.1# route add default gw 192.168.3.1D主机开启路由转发功能# echo 1 > /proc/sys/net/ipv4/ip_forward 5)E主机上操作:ip为192.168.4.2,设置网关为192.168.4.1# route add default gw 192.168.4.1 |
Linux下路由配置梳理(转)的更多相关文章
- Linux下路由配置梳理
在日常运维作业中,经常会碰到路由表的操作.下面就linux运维中的路由操作做一梳理:---------------------------------------------------------- ...
- linux 下路由配置
转自 https://www.cnblogs.com/kevingrace/p/6490627.html 在日常运维作业中,经常会碰到路由表的操作.下面就linux运维中的路由操作做一梳理:----- ...
- Vsftp的PASV mode(被动模式传送)和Port模式及 Linux下VsFTP配置全方案
什么叫做PASV mode(被动模式传送)?他是如何工作的? FTP的连接一般是有两个连接的,一个是客户程和服务器传输命令的,另一个是数据传送的连接.FTP服务程序一般会支持两种不同的模式,一种是Po ...
- linux下IPTABLES配置详解 (防火墙命令)
linux下IPTABLES配置详解 -A RH-Firewall-1-INPUT -p tcp -m state --state NEW -m tcp --dport 24000 -j ACCEPT ...
- (转)yi_meng linux 下 ifcfg-eth0 配置 以及ifconfig、ifup、ifdown区别
linux 下 ifcfg-eth0 配置 以及ifconfig.ifup.ifdown区别 原文:https://www.cnblogs.com/yi-meng/p/3214471.html这3个命 ...
- linux 下 ifcfg-eth0 配置 以及ifconfig、ifup、ifdown区别
这3个命令的用途都是启动网络接口,不过,ifup与ifdown仅就 /etc/sysconfig/network- scripts内的ifcfg-ethx(x为数字)进行启动或关闭的操作,并不能直接修 ...
- Linux 下安装配置 JDK7
Linux 下安装配置 JDK7 配置环境(debian 7) 自从从Oracle收购Sun近三年来,已经有很多变化.早在8月,甲骨文将“Operating System Distributor Li ...
- 【转】Linux下nginx配置https协议访问的方法
一.配置nginx支持https协议访问,需要在编译安装nginx的时候添加相应的模块--with-http_ssl_module 查看nginx编译参数:/usr/local/nginx/sbin/ ...
- (转载)Linux下安装配置MySQL+Apache+PHP+WordPress的详细笔记
Linux下安装配置MySQL+Apache+PHP+WordPress的详细笔记 Linux下配LMAP环境,花了我好几天的时间.之前没有配置过,网上的安装资料比较混乱,加上我用的版本问题,安装过程 ...
随机推荐
- C# 扩展方法——mysql-dapper(MySqlMapperExtensions)
其他扩展方法详见:https://www.cnblogs.com/zhuanjiao/p/12060937.html 反射比较耗费性能,反射得到属性进行缓存 根据反射得到的属性,进行动态拼接sql语句 ...
- Burpsuite的Intruder模块发现敏感目录
提前配置好浏览器的代理设置,并且成功访问了目标地址(这里是http://192.168.146.133/WackoPicko) 1.在burpsuite的proxy栏目中,找到对WackoPicko路 ...
- 图片url 设置大小
假设有一个图片url为:http://localhost/PictureUrl/ImgURL.aspx?PicUrl=.//testImg\test.jpg (文件夹testImg下有个文件test. ...
- 21. ClustrixDB 识别平台限制
本节描述集群性能上潜在的限制平台因素,如何度量集群是否接近或超过这些限制,以及纠正这些条件的可用选项.“平台因素”指的是硬件资源,如CPU.内存.磁盘和网络I/O子系统.有关潜在的软件相关因素,请参见 ...
- LU分解法求逆矩阵 C语言实现
最近在网上找了下,没有找到我想要的C语言版本,找到的也是错误的.故自己写了一个,并进行了相关测试,贴出来分享. 具体的LU分解算法就不细说了,随便找本书就知道了,关键是分解的处理流程,细节特别容易出错 ...
- PTA 道长你想怎么死
道长你想怎么死 (25 分) 故事:[ 他身着白衣,撑着伞朝我走来.说要送我回家.而我早已陷入他那对深邃的眼眸中,心内一阵悸动.他一把拉我入伞下.我得知他是山上的道士,也刚好下山采药.他把伞赠予我,一 ...
- numpy.bincount()
numpy.bincount详解 numpy.bincount(x, weights=None,minlength=0) 参数中要求x是一个array_like,一维的并且包含非负整数. In [19 ...
- LinkedList类源码浅析(一)
1.先来看一看LinkedList类的字段和构造方法 size记录链表的长度,first永远指向链表的第一个元素,last永远指向链表的最后一个元素 提供两个构造方法,一个无参的构造方法,一个接受一个 ...
- is == 编码与解码
is 和 == 主要是数字和字符串的比较 1 区别: ==比较的是两边的值 is比较的是两边值的id id获取的方法 id() 2 小数据池: -5~256 3 字符串中特殊字符有id ...
- oracle存储过程及sql优化-(二)
接下来比较重要,我会先贴出一个存储过程,根据这个存储过程讲解 PROCEDURE AP_CXBB_GT3_SBFGL_SBFYJSQC (OUT_RECORD OUT SYS_REFCURSOR, P ...