Linux系统多网卡环境下的路由配置详解
作者:varlemon 发布时间:2023-11-02 16:59:35
Linux下路由配置命令
1. 添加主机路由
route add -host 192.168.1.11 dev eth0
route add -host 192.168.1.12 gw 192.168.1.1
2. 添加网络路由
route add -net 192.168.1.11 netmask 255.255.255.0 eth0
route add -net 192.168.1.11 netmask 255.255.255.0 gw 192.168.1.1
route add -net 192.168.1.0/24 eth0
route add -net 192.168.1.0/24 gw 192.168.1.1
3. 添加默认网关
route add default gw 192.168.1.1
4. 删除路由
route del -host 192.168.1.11 dev eth0
5. 删除默认路由
route del default gw 192.168.1.1
Linux下配置永久路由的几种方式
1. 在/etc/rc.local
里添加路由信息
route add -net 192.168.1.0/24 dev eth0
# 或者
route add -net 192.168.1.0 netmask 255.255.255.0 gw 192.168.1.1
2. 在/etc/sysconfig/network
里追加
GATEWAY=[网关IP或者网关网卡名称]
3. /etc/sysconfig/static-routes
any net 192.168.1.0/24 gw 192.168.1.1
# 或者
any net 192.168.1.0 netmask 255.255.255.0 gw 192.168.1.1
4. 开启IP转发
1.临时开启
echo "1" > /proc/sys/net/ipv4/ip_forward
2.永久开启
vim /etc/sysctl.conf
修改net.ipv4.ip_forward=1
实验:配置双网卡主机同时使用内网和外网
本实验的背景是笔者在实践中遇到过的一个问题,本实验尽量还原当时的网络环境。仅当做一份笔记,同时分享给遇到此问题的同学。
奈何我现在没有硬件呀(T_T)...只能拿VMware Workstation和eNSP来模拟实验环境了。
问题背景
如下图拓扑所示,如果去掉client
节点,内网和外网就是相互隔离的网络。
但是实际情况是,client
节点既需要访问外网资源,又需要访问内网资源,而client
只能配置一条默认路由。如果将默认路由配置在外网网卡,client
可以访问172.16.2.0/24
网络的资源和外网的资源,但是其余内网资源将无法访问;如果将默认路由配置在内网网卡,client
虽然可以完全访问内网资源,但是却不能访问外网资源。
怎么解决呢?
实验环境
VMware Workstation Pro
4台最小化安装的CentOS 7.3虚拟机
华为eNSP模拟器
实验拓扑
去掉client
节点,内网和外网是隔离的网络。
外网网络为10.0.0.0/16
,代表运营商的接入网;
内网网络为172.16.0.0/16
,代表内网部分(该部分为了安全,不允许对互联网的直接访问)。
其中:
client
为双网卡的主机,两网卡网段分别为10.0.0.0/16
、172.16.2.0/24
;server2
为172.16.2.0/24
网段的服务器;server3
为172.16.3.0/24
网段的服务器;server4
为172.16.4.0/24
网段的服务器。
网络规划
IP分配
节点名称 | IP地址 | 子网掩码 | 备注 |
---|---|---|---|
client | 10.0.0.101 | 255.255.0.0 | client的外网网卡 |
172.16.2.101 | 255.255.255.0 | client的内网网卡 | |
Server2 | 172.16.2.11 | 255.255.255.0 | 172.16.2.0/24网段的某台服务器 |
Server3 | 172.16.3.11 | 255.255.255.0 | 172.16.3.0/24网段的某台服务器 |
Server4 | 172.16.4.11 | 255.255.255.0 | 172.16.4.0/24网段的某台服务器 |
内网路由器 | 172.16.2.254 | 255.255.255.0 | 172.16.2.0/24的网关 |
172.16.3.254 | 255.255.255.0 | 172.16.3.0/24的网关 | |
172.16.4.254 | 255.255.255.0 | 172.16.4.0/24的网关 |
虚机网卡类型
网络名称 | VMware网卡类型 | 网络范围 |
---|---|---|
运营商网络 | 桥接 | 10.0.0.0/16 |
VMnet2 | 仅主机 | 172.16.2.0/24 |
VMnet3 | 仅主机 | 172.16.3.0/24 |
VMnet4 | 仅主机 | 172.16.4.0/24 |
内网路由器如何实现呢?
VMnet2、VMnet3、VMnet4均为仅主机模式,那么常规情况下,只有其网络内的各计算机之间才可以通信,要怎样才能实现三个网络间的通信呢?
答案是使用华为eNSP模拟器中的Cloud。使用Cloud设备可以将eNSP中的路由器和VMware虚拟机的网卡连接起来。
配置内网环境
配置eNSP的路由器
接口 | IP地址 | 子网掩码 |
---|---|---|
G0/0/0 | 172.16.2.254 | 255.255.255.0 |
G0/0/1 | 172.16.3.254 | 255.255.255.0 |
G0/0/2 | 172.16.4.254 | 255.255.255.0 |
<huawei>system-view
[huawei]int g0/0/0
[Huawei-GigabitEthernet0/0/0]ip address 172.16.2.254 255.255.255.0
[Huawei-GigabitEthernet0/0/0]quit
[huawei]int g0/0/1
[Huawei-GigabitEthernet0/0/1]ip address 172.16.3.254 255.255.255.0
[Huawei-GigabitEthernet0/0/1]quit
[huawei]int g0/0/2
[Huawei-GigabitEthernet0/0/2]ip address 172.16.4.254 255.255.255.0
[Huawei-GigabitEthernet0/0/2]quit
[huawei]
修改虚机的IP地址
client
网卡名称 | IP地址 | 子网掩码 | 默认网关 | 备注 |
---|---|---|---|---|
ens33 | 10.0.0.101 | 255.255.0.0 | 10.0.0.1 | 外网网卡 |
ens37 | 172.16.2.101 | 255.255.255.0 | 内网网卡 |
server2
网卡名称 | IP地址 | 子网掩码 | 默认网关 | 备注 |
---|---|---|---|---|
ens33 | 172.16.2.11 | 255.255.255.0 | 172.16.2.254 |
server3
网卡名称 | IP地址 | 子网掩码 | 默认网关 | 备注 |
---|---|---|---|---|
ens33 | 172.16.3.11 | 255.255.255.0 | 172.16.3.254 |
server4
网卡名称 | IP地址 | 子网掩码 | 默认网关 | 备注 |
---|---|---|---|---|
ens33 | 172.16.4.11 | 255.255.255.0 | 172.16.4.254 |
在server上搭建HTTP服务
以server2
为例:
使用Python创建一个简单的HTTP服务
cd ~
echo "server2" > index.html
python -m SimpleHTTPServer 8080
对照试验
在client
上访问外网
ping www.baidu.com -c 4
在client
上访问server2
ping 172.16.2.11 -c 4
在client
上访问server3
ping 172.16.3.11 -c 4
在client
上访问server4
ping 172.16.4.11 -c 4
在对照试验中可以看到,在client
将默认网关配置在外网网卡的情况下,双网卡的client
可以正常访问外网和内网的172.16.2.0/24
部分,而172.16.3.0/24
和172.16.4.0/24
是不能访问到的。
为什么client
能访问172.16.2.0/24
网络,而不能访问172.16.0.0/16
的其余网络呢?
因为client
位于172.16.2.0/24
网络内,在网络内进行通信,数据包不用发送至其他网络,当然默认网关也就不起作用了。
而当client
与172.16.0.0/16
的其余网络通信时,client
的路由表没有记载发往目的地址的路径,所以client
只能傻傻的把数据包发送给默认网关,从此数据包和真正的目的地址就“南辕北辙”了。当然ping的结果就是网络不可达。
路由配置
在client
上查看路由表
route
在client
上添加路由
route add -net 172.16.0.0/16 gw 172.16.2.254
永久配置,则在/etc/rc.local
里添加路由信息
route add -net 172.16.0.0/16 gw 172.16.2.254
查看路由表
route
实验结果
检测连通性
ping www.baidu.com -c 4
ping 172.16.2.11 -c 4
ping 172.16.3.11 -c 4
ping 172.16.4.11 -c 4
访问内外网资源
curl http://www.baidu.com/
curl http://172.16.2.11:8080/index.html
curl http://172.16.3.11:8080/index.html
curl http://172.16.4.11:8080/index.html
解决的办法很简单,就是1条命令而已。
但是蕴藏在这条命令背后的原理、概念、理论,则需要我们进行深究!
来源:https://www.cnblogs.com/connect/p/linux-static-route.html
猜你喜欢
- 在巡讲过程中,发布商都对我们新推出的产品 – 搜索联盟 非常感兴趣,也询问了很多搜索联盟相关的问题。我们收集了几个主要的问题,并做以下的解答
- 11月12日消息,今天,百度知道文档分享平台正式上线,为百度用户分享文档提供了一个方便而实用的渠道。“百度知道文档分享&
- 3月17日消息 17日上午,国内天使投资第一人薛蛮子在“创新中国2011”活动上分享自己的创业经验,称创业者要花费90%的时间来挑选适合进入
- 针对BIND DNS服务软件的安全配置情况,我们要充分利用BIND自身已经实现的保护功能,加强BIND安全性,从而能抵御目前已知的BIND安
- 本文以redhat AS 4.0为例:首先要安装linux下的vsftp软件包。rpm -qa|gerp vsftpd //查找vsftpd
- 文字一出各路诸侯杀出,一个措手不及待吾友商发布!前不久视觉组同事们讨论了一个老话题 — 网站图片格式问题和对性能产生的影响其实大家每天都与图
- #最关键参数,默认为5,修改为0 表示不要重发net.ipv4.tcp_synack_retries = 0#半连接队列长度net.ipv4
- 之前我们就报道过Chrome 即将迎来5.0 正式版,而且还将带来首个Mac 和Linux 平台的正式版本,今天这一切终于实现了,Chrom
- 自打90年代末开始接触电脑就着迷了,直到现在,从DOS学起,经历了Windows好几个版本,同时经历了互连网的风风雨雨,一路走来,算算自己也
- 方法1、因为没有像PHP自带的ReWrite模块,所以需要下载IIS Rewrite模块:www.helicontech.com/downl
- 最近以来,许多关系老百姓衣食住行的B2C网站开始大量涌现,有在网上卖童装、卖衬衫、卖内衣、卖鞋子、卖米面粮油的,一应俱全。而一家以鞋业行业网
- 随着国际互连网的发展,一些企业建立了自己的INTRANET,并通过专线与INTERNET连通。为了保证企业内部网的安全,防止非法入侵,需要使
- 注册表编辑器使用不当可造成严重问题,这些问题可能需要重新安装操作系统。Microsoft 不保证能够解决因为注册表编辑器使用不当而产生的问题
- 微软的Windows Server 2003中防火墙的功能如此之简陋,让很多系统管理员将其视为鸡肋,它一直是一个简单的、仅支持入站防护、基于
- 如果你的VPS上有个文件要传到另一个VPS上,最最简单的方法有两种。一个是先下载到本地,然后上传到另一个VPS,这个方法的缺点是速度慢。另一
- 在进行双机热备、集群及高可用性软件产品的选择时,可按以下步骤进行:1. 明确应用的方式与要求:是双机方式还是多点集群?或者是目前使用双机、以
- 相信大家都受过病毒煎熬,下面是我从自学编程网转载过来,看了,觉得不错,所以特来献给站长朋友,入侵检测既是一项非常重要的服务器日常管理工作,也
- Windows Server 2008系统事件日志功能记录了服务器系统中发生的各种重要事情,比方说网络访问、系统登录、程序运行、资源调用等,
- 新娘们是不是会觉得自己拍出来的婚纱照总感觉哪里胖了。这么重要的幸福记忆变得不够完美。别着急小编教你用“美图秀秀&
- 子域型:如网店域名为www.abc.com(abc为任意字符)论坛域名必须为http://???.abc.com(???和abc都为任意字符