linux如何在网关里添加路由表,Linux下配置路由表

本文详细介绍了路由的基本概念,包括路由、路由器和路由表,以及直连路由、静态路由和默认路由的区别。特别强调了静态路由和默认路由的特性及应用场景。此外,还探讨了Linux中的路由操作,如route命令的使用,以及如何配置主机路由、网络路由和默认路由。同时,解释了数据包在路由器中的转发过程和封装变化,以及Linux内核路由表的查看方式。最后,讨论了Linux中开启包转发和配置静态路由的方法。
摘要由CSDN通过智能技术生成

66b52468c121889b900d4956032f1009.png

8种机械键盘轴体对比

本人程序员,要买一个写代码的键盘,请问红轴和茶轴怎么选?

路由的基础知识

路由概念

路由: 跨越从源主机到目标主机的一个互联网络来转发数据包的过程

路由器:能够将数据包转发到正确的目的地,并在转发过程中选择最佳路径的设备

路由表:在路由器中维护的路由条目,路由器根据路由表做路径选择

直连路由:当在路由器上配置了接口的IP地址,并且接口状态为up的时候,路由表中就出现直连路由项

静态路由:是由管理员手工配置的,是单向的。

默认路由:当路由器在路由表中找不到目标网络的路由条目时,路由器把请求转发到默认路由接口 。

静态路由和默认路由的特点静态路由特点:

路由表是手工设置的;

除非网络管理员干预,否则静态路由不会发生变化;

路由表的形成不需要占用网络资源;

适用环境:一般用于网络规模很小、拓扑结构固定的网络中。默认路由特点:

在所有路由类型中,默认路由的优先级最低

适用环境:一般应用在只有一个出口的末端网络中或作为其他路由的补充

浮动静态路由:

路由表中存在相同目标网络的路由条目时,根据路由条目优先级的高低,将请求转发到相应端口;

链路冗余的作用;

路由器转发数据包时的封装过程

源IP和目标IP不发生变化,在网络的每一段传输时,源和目标MAC发生变化,进行重新封装,分别是每一段的源和目标地址。

要完成对数据包的路由,一个路由器必须至少了解以下内容:目的地址

相连路由器,并可以从哪里获得远程网络的信息

到所有远程网络的可能路由

到达每个远程网络的最佳路由

如何维护并验证路由信息

路由和交换的对比

路由工作在网络层:根据“路由表”转发数据

路由选择

路由转发

交换工作在数据链路层:根据“MAC地址表”转发数据

硬件转发

Linux中的route

使用route -n命令查看Linux内核路由表1

2

3

4

5

6

7Kernel IP routing table

Destination Gateway Genmask Flags Metric Ref Use Iface

0.0.0.0 192.168.1.1 0.0.0.0 UG 202 0 0 eth0

0.0.0.0 10.89.0.1 0.0.0.0 UG 303 0 0 wlan0

10.89.0.0 0.0.0.0 255.255.240.0 U 303 0 0 wlan0

192.168.1.0 0.0.0.0 255.255.255.0 U 202 0 0 eth0

输出说明:输出项说明Destination目标网段或者主机

Gateway网关地址,*表示目标是本主机所属的网络,不需要路由

Genmask网络掩码

Flags标记

Metric路由距离,到达指定网络所需要的中转数

Ref路由项引用次数

Use此路由项被路由软件查找的次数

Iface此路由项对应的输出接口

Flags的一些标记含义:标记含义U路由是活动的

H目标是个主机

G路由指向网关

R恢复动态路由产生的表项

D由路由的后台进程动态的安装

M由路由的后台进程修改

!拒绝路由

三种路由类型说明1.主机路由:

主机路由是路由选择表中指向单个IP地址或主机名的路由记录。主机路由的Flags字段为H。例如,在下面的示例中,本地主机通过IP地址192.168.1.1的路由器到达IP地址为10.89.0.10的主机。

添加主机路由时,需要指定网络 ID 和主机 ID,此时需要设置 netmask 255.255.255.255。1

2Destination Gateway Genmask Flags Metric Ref Use Iface

10.89.0.10 192.168.1.1 255.255.255.255 UH 0 0 0 eth0

2.网络路由:

网络路由是代表主机可以到达的网络。网络路由的Flags字段为N。例如,在下面的示例中,本地主机将发送到网络192.19.12的数据包转发到IP地址为192.168.1.1的路由器。

添加网络路由时,只需指定网络 ID,通过 netmask 设置掩码长度。1

2Destination Gateway Genmask Flags Metric Ref Use Iface

192.19.12 192.168.1.1 255.255.255.0 UN 0 0 0 eth0

3.默认路由:

当主机不能在路由表中查找到目标主机的IP地址或网络路由时,数据包就被发送到默认路由(默认网关)上。默认路由的Flags字段为G。例如,在下面的示例中,默认路由是IP地址为192.168.1.1的路由器。1

2Destination Gateway Genmask Flags Metric Ref Use Iface

0.0.0.0 192.168.1.1 0.0.0.0 UG 202 0 0 eth0

配置路由route的命令

设置和查看路由表都可以用 route 命令,设置内核路由表的命令格式是:1route [add|del] [-net|-host] target [netmask Nm] [gw Gw] [[dev] If]

参数解释:参数解释add添加一条路由规则

del删除一条路由规则

-net目的地址是一个网络

-host目的地址是一个主机

target目的网络或主机

netmask目的地址的网络掩码

gw路由数据包通过的网关

dev为路由指定的网络接口

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 默认没有这个文档 ,得手动创建一个

设置包转发

在Linux中默认的内核配置已经包含了路由功能,但默认并没有在系统启动时启用此功能;

开启Linux的路由功能可以通过调整内核的网络参数来实现,方法如下:1

2

3

4

5

6

7

8

9

10临时开启路由功能:

# echo 1 > /proc/sys/net/ipv4/ip_forward

或者

# sysctl -w net.ipv4.ip_forward=1

永久开启路由功能

# vim /etc/sysctl.conf

net.ipv4.ip_forward = 1

# sysctl -p

静态路由配置

添加静态路由到路由表的语法如下:1ip route [destination_network] [mask] [next-hop_address] administrative_distance]

参数解释:参数解释destination_network需要发布到路由表中的网段

mask在这一网络上使用的子网掩码

next-hop_address下一跳路由器的地址

administrative_distance默认时,静态路由有一个取值为1 的管理性距离。在这个命令的尾部添加管理权来修改这个默认值。

例如:1ip route 172.16.1.0 255.255.255.0 172.16.2.1

查看路由表除了使用route -n命令外,还可以使用ip route:1

2

3

4default via 192.168.1.1 dev eth0 src 192.168.1.109 metric 202

default via 10.89.0.1 dev wlan0 src 10.89.2.144 metric 303

10.89.0.0/20 dev wlan0 proto kernel scope link src 10.89.2.144 metric 303

192.168.1.0/24 dev eth0 proto kernel scope link src 192.168.1.109 metric 202

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值