Linux路由转发+多网卡配置(route命令)

Posted 爱敲代码的三毛

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux路由转发+多网卡配置(route命令)相关的知识,希望对你有一定的参考价值。

文章目录


route命令

route -n 查看路由,显示ip,不解析
route del default gw 10.1.1.254 删除默认路由
route add default gw 192.168.1.110 添加一个默认网关,把所有不知道的网络交给网关来转发
route add -net 192.168.2.0/24 dev eth0 对一个网络添加一个新的路由(另一个网段)
route del -net 192.168.2.0/24 删除路由

一、路由表

什么是交换?什么是路由?什么是路由表?

  1. 交换是指同网络访问(两台机器连在同一交换机上,配置同网段的不同IP就可以直接通讯)
  2. 路由就是跨网络访问(路径选择)
  3. 路由表是记录路由信息的表,在Linux中首先是一张可见的,可更改的表,它的作用就是当数据包发到Linux的时候,系统(或者说内核)就根据这张表中定义好的信息来决定这个数据包接下来该怎么走

1. 查看路由表信息

命令:route -n
作用:用来查看和设置路由表信息

2. 读懂路由信息

示例

示例1:

按照上面的路由表来看,如果我ping一个公网IP:14.200.149.30,应该怎么走?

  1. 先看目标ip是否为本地ip,如果是就直接访问本地IP;若果不存在。则去找路由表里是否有需要访问的网段
  2. 如果路由表有这个ip则从这个路由的表中的对应的网卡出去;如果路由表中没有要访问的网段,则会找默认路由,也就是网关
  3. 如果网关也没有的话,则就会报错

示例2:

按照上面的路由表来看,如果ping一个局域网ip:192.168.122.10,又会怎么走?

ping 192.168.122.10不会走网关,而是走本地路由从 eth0网卡出去,因为路由表有192.168.122.0的路由

3. 添加和删除网关

注意:如果要添加一个网关那么,就要添加一个能够到达该网关的目标网络地址(要和网关在同一个网段)

  1. 临时删除网关,马上生效
    命令:route del default gw [ip]

  2. 临时增加网关,马上生效

命令:route add default gw [ip]

没有一条到达该网关的路报错

使用命令:route add -net [ip] dev [网卡名] 添加一条到达指定网关的路
删除目标网络命令:route del -net [ip] dev [网卡名]

永久增加网关

修改配置文件
路径:/etc/sysconfig/network-scripts/ifcfg-[网卡名]


注意事项:

  1. 加网关只能加你已经有的路由网段里的一个IP才行(此IP不一定存在)
  2. 加网关可以不用指定子网掩码(因为是已有的一个网段的ip,所以掩码已经确认了)

4. 多网卡配置(仅主机+NET模式)

添加一张NET模式下网卡



添加一张网卡后

创建一个配置文件

添加的新网卡名叫ens36


创建一个配置文件

修改ifcfg-ens36配置文件


保存退出,重启网卡
systemctl restart network

双网卡注意事项

一个linux服务器上能有几个有效网关?
准确来说:一个路由表上可以加多个网关,但只有一个生效。

我一台linux上如果有双物理网卡,请问可不可以两个网卡配置同网段的不同IP呢?
eth0 10.1.1.1/24
eth1 10.1.1.2/24

如果两个网卡同网段,则会有下面两条路由
10.1.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eth0
10.1.1.0 0.0.0.0 255.255.255.0 U 0 0 0 eht1

结果:
它会实现从两张网卡进来的包,却从一张网卡出去,问题就产生了。假设eth0网卡有问题时,路由表里匹配到第一条后,依然会走eth0网卡,而不会走eth1。
也有解决方法(比如多路由表或者双网卡绑定),这里不涉及。

二、路由选择

1. 环境准备

三台虚拟机的网络模式都为仅主机模式

  • 主机1 ip:10.1.1.1/24
    主机1作为网关服务器,开启路由转发功能
  • 主机2 ip:192.168.0.254/24
  • 主机3 ip:172.16.0.254/24

要求
实现不同网络(172.16.0.0/24192.168.0.0/24)直间的互通,使用第三方主机1作为路由进行转发

2. 步骤

1)开启路由转发功能

主机1中间人完成一下任务

临时开启路由转发功能
命令:echo 1 > /proc/sys/net/ipv4/ip_forward


永久开启
修改配置文件
vim /etc/sysctl.conf
添加 net.ipv4.ip_forward = 1

2)分别添加node2和node3两台主机所在的网络

在主机1中
添加到达主机2的路,命令:route add -net 192.168.0.0/24 dev ens33
添加到达主机3的路,命令:route add -net 172.16.0.0/24 ens33

3)分别配置主机2和主机3的ip和网关

把主机2和主机3的网关配置成主机1的ip
注意:在配置网关前,一定要先添加一条能到网关的路,也就是添加一个和网关在同一网段的目标网络IP

在主机2和主机3里都执行添加目标网络和默认网关的命令命令
注意:ens33是网卡名
route add -net 10.1.1.0/24 dev ens33
添加好到网关的路之后,再添加默认网关(也就是主机1的Ip,通过主机1来实现路由转发)
命令:route add default gw 10.1.1.1

4)测试

在主机1里分别ping主机2和主机3


接着测试主机3和主机2之间互相ping,看看是否联通



最后实现借助中间主机1路由转发,实现主机2和主机3之间通信

高性能云服务器 精品线路独享带宽,毫秒延迟,年中盛惠 1 折起

以上是关于Linux路由转发+多网卡配置(route命令)的主要内容,如果未能解决你的问题,请参考以下文章

linux怎么设置永久路由

Linux 路由配置问题!!200分

linux 多网卡多路由表实现策略路由

Linux添加永久静态路由信息

用route命令添加永久路由

Linux网络配置实战服务器Network静态路由配置