【Linux服务器双IP配置】如何实现不同IP的双网卡同时上网?
一、环境和知识预备
我遇到问题的生产机器是CentOS release 6.8系统,不过这并不影响问题的解决,本质上都是一样的。
网关:一个网络连接到另一个网络的关口,也就是实现网络互连,俗称网络连接器。
DNS:域名解析服务器,是把网址变成IP地址的服务器。
上网流程大致如下:
服务器IP <--> 对应的网关 <--> 网络
也就是说网关作为一个中介,如果没有对应的网关,那么是无法进行正确通信、上网的。
二、问题介绍
一般我们在像运营商申请专线宽带的时候,运营商都会提供【IP、网关、掩码、DNS地址】这些基本的网卡配置信息。如果只有一张网卡,那么基本是没有问题的,这也是很常见的一个配置步骤。
1、获取网卡名,底下表红色的就是对应的网卡名称,打马赛克的位置就是分配的公网地址(ipv4),inet表示ipv4地址,inet6表示ipv6的地址。
2、切换到/etc/sysconfig/network-scripts目录下,把配置写到对应的网卡配置文件中,文件名是【ifcfg-网卡名称】,我的这边是ifcfg-em1。
3、修改配置如下:
1 DEVICE=ens33 #网卡名称
2 HWADDR=14:18:77:3B:6F:01 #MAC地址
3 TYPE=Ethernet #网卡类型
4 UUID=314d1b96-70b2-498a-8711-6cb5ab264464 #唯一标识
5 ONBOOT=yes #开机激活
6 BOOTPROTO=static #网卡获取IP地址的方式,一般有【none,dhcp,static】这些,dhcp是自动获取IP的,其他都是固定的
7 IPADDR=100.196.184.188 #IP地址,如果BOOTPROTO=dhcp选择动态获取IP的话,那么这里就不需要配置IP。
8 GATEWAY=100.196.184.19 #默认网关地址!!!
9 NETMASK=255.255.255.248 #掩码
10 DNS1=51.136.192.6 #默认主DNS地址
11 DNS2=50.196.165.2 #默认备DNS地址,后面可以继续递增列下去,DNS3,DNS4
12 NM_CONTROLLED=no #网卡是否允许用 NetworkManager 程序管理,使用于非服务器
13 MTU=9000 #网络上传送的最大数据包
4、单网卡情况下,你这么一配置,重启一下网络服务。【service network restart】或者【systemctl network restart】运行一下就可以了。
因为就一张网卡,不管你配置的是全局还是局部,都能生效,没有冲突问题。
如果有多张网卡,那么就会出现冲突问题了。冲突的原因是GATEWAY和DNS的配置,这两个配置的表示默认的地址。多张网卡的配置ifcfg-em1,ifcfg-em2,ifcfg-em3...,后面的配置就会把前面的配置直接进行覆盖操作。啥意思呢?就是em1的网关是A,em2的网关是B,启动的时候系统会去读取这些配置文件的信息,加载em1的配置时,默认网关是A;接着,加载em2的配置时,默认网关变成了B。这样A的IP就走不通了。
所以在有多个网卡的情况,不应该只使用一个默认的网关来实现通信,因为不同网卡的网关不一样会导致一部分网卡由于网关不适用导致不能使用的情况。
三、问题解决
我们可以通过为每个网卡配置单独的规则来实现通信,em1对应网关A,em2对应网关B,em3对应网关C...这样每个网卡都选择正确自己的网关,就不会有默认网关带来的冲突问题了。如何操作?请看下面:
首先要知道Linux携带了自己的路由配置的一些命令。
ip rule和ip route: ip rule是用来管理路由规则的,ip route是管理路由表的,底下是这两个的一些参数配置,有兴趣的可以看看,没兴趣的直接跳过下面这个代码段。
Usage: ip rule [ list | add | del | flush ] SELECTOR ACTION
SELECTOR := [ not ] [ from PREFIX ] [ to PREFIX ] [ tos TOS ] [ fwmark FWMARK[/MASK] ]
[ dev STRING ] [ pref NUMBER ]
ACTION := [ table TABLE_ID ]
[ realms [SRCREALM/]DSTREALM ]
[ goto NUMBER ]
TABLE_ID := [ local | main | default | NUMBER ] Usage: ip route { list | flush } SELECTOR
ip route get ADDRESS [ from ADDRESS iif STRING ]
[ oif STRING ] [ tos TOS ]
ip route { add | del | change | append | replace | monitor } ROUTE
SELECTOR := [ root PREFIX ] [ match PREFIX ] [ exact PREFIX ]
[ table TABLE_ID ] [ proto RTPROTO ]
[ type TYPE ] [ scope SCOPE ]
ROUTE := NODE_SPEC [ INFO_SPEC ]
NODE_SPEC := [ TYPE ] PREFIX [ tos TOS ]
[ table TABLE_ID ] [ proto RTPROTO ]
[ scope SCOPE ] [ metric METRIC ]
INFO_SPEC := NH OPTIONS FLAGS [ nexthop NH ]...
NH := [ via ADDRESS ] [ dev STRING ] [ weight NUMBER ] NHFLAGS
OPTIONS := FLAGS [ mtu NUMBER ] [ advmss NUMBER ]
[ rtt TIME ] [ rttvar TIME ] [reordering NUMBER ]
[ window NUMBER] [ cwnd NUMBER ] [ initcwnd NUMBER ]
[ ssthresh NUMBER ] [ realms REALM ] [ src ADDRESS ]
[ rto_min TIME ] [ hoplimit NUMBER ] [ initrwnd NUMBER ]
TYPE := [ unicast | local | broadcast | multicast | throw |
unreachable | prohibit | blackhole | nat ]
TABLE_ID := [ local | main | default | all | NUMBER ]
SCOPE := [ host | link | global | NUMBER ]
FLAGS := [ equalize ]
MP_ALGO := { rr | drr | random | wrandom }
NHFLAGS := [ onlink | pervasive ]
RTPROTO := [ kernel | boot | static | NUMBER ]
TIME := NUMBER[s|ms]
1、切换到/etc/sysconfig/network-scripts目录下,把配置写到对应的网卡配置文件中,文件名是【ifcfg-网卡名称】。
2、修改配置如下(不需要再配置GATEWAY):
if-ens33网卡配置文件
DEVICE=ens33 #网卡名称
HWADDR=14:18:77:3B:6F:01 #MAC地址
TYPE=Ethernet #网卡类型
UUID=314d1b96-70b2-498a-8711-6cb5ab264464 #唯一标识
ONBOOT=yes #开机激活
BOOTPROTO=static #网卡获取IP地址的方式,一般有【none,dhcp,static】这些,dhcp是自动获取IP的,其他都是固定的
IPADDR=100.196.184.188 #IP地址,如果BOOTPROTO=dhcp选择动态获取IP的话,那么这里就不需要配置IP。
####GATEWAY=100.196.184.19 #默认网关地址!!!
NETMASK=255.255.255.248 #掩码
DNS1=51.136.192.6 #默认主DNS地址
DNS2=50.196.165.2 #默认备DNS地址,后面可以继续递增列下去,DNS3,DNS4
NM_CONTROLLED=no #网卡是否允许用 NetworkManager 程序管理,使用于非服务器
MTU=9000 #网络上传送的最大数据包
if-ens34网卡配置文件
DEVICE=ens33 #网卡名称
HWADDR=14:18:77:3B:6F:02 #MAC地址
TYPE=Ethernet #网卡类型
UUID=314d1b96-70b2-498a-8711-6cb11b264464 #唯一标识
ONBOOT=yes #开机激活
BOOTPROTO=static #网卡获取IP地址的方式,一般有【none,dhcp,static】这些,dhcp是自动获取IP的,其他都是固定的
IPADDR=88.196.184.188 #IP地址,如果BOOTPROTO=dhcp选择动态获取IP的话,那么这里就不需要配置IP。
####GATEWAY=88.196.184.19 #默认网关地址!!!
NETMASK=255.255.255.248 #掩码
DNS1=51.136.192.6 #默认主DNS地址
DNS2=50.196.165.2 #默认备DNS地址,后面可以继续递增列下去,DNS3,DNS4
NM_CONTROLLED=no #网卡是否允许用 NetworkManager 程序管理,使用于非服务器
MTU=9000 #网络上传送的最大数据包
3、配置ens33的默认路由
【配置规则如下】:
ip rule add from 网卡IP table 表数字
ip route add default via 网关 dev 网卡名 table 表数字
配置ens33的路由规则(table后面的数字可以自己取,如果冲突系统会提示已存在,换一个不存在的就好,可以通过【ip rule show】命令查看已配置的内容)
ip rule add from 100.196.184.188 table 1
配置ens33的路由表(可以通过【ip route show】命令查看已配置的内容)
ip route add default via 100.196.184.19 dev ens33 table 1
4、配置ens34的默认路由
配置ens34的路由规则(table后面的数字可以自己取,如果冲突系统会提示已存在,换一个不存在的就好,可以通过【ip rule show】命令查看已配置的内容)
ip rule add from 88.196.184.188 table 2
配置ens34的路由表(可以通过【ip route show】命令查看已配置的内容)
ip route add default via 88.196.184.19 dev ens34 table 2
... 如果有多张继续参照上诉步骤配置下去。
5、通过ping命令验证
ping -I 网卡名或者IP www.baidu.com
如果正常的话就是成功了,否则检查一下配置。如果配置错误,可以通过对应的删除命令清理规则,就是把命令的add改成del。比如:
ip rule add from 88.196.184.188 table 2
对应的删除操作是:
ip rule del from 88.196.184.188 table 2
四、总结
这就是我今天一个解决这个问题的一个过程,就是把【网卡使用默认的网关】修改成【网卡自己使用单独的一个路由规则】来实现多IP同时上网的问题。期间,可以通过tcpdump命令,traceroute命令等来协助问题排查。这些命令比较简单就不介绍啦。tcpdump命令可以参照我之前写的:
https://www.cnblogs.com/luozhuzhu/p/13405350.html
好了,今日分享到此结束,咱们下期再会!谢谢大家的观看!
【Linux服务器双IP配置】如何实现不同IP的双网卡同时上网?的更多相关文章
- linux服务器应用NTP配置时间同步
linux服务器应用NTP配置时间同步 • 为什么建议使用ntpd而不是ntpdate? #####原因很简单,ntpd是步进式的逐渐调整时间,而ntpdate是断点更新,比如现在服务器时间是9.18 ...
- linux服务器基本安全配置手册
转:忘了在哪转的,直接复制到笔记里了,贴出来分享 假如你想要搭建一个Linux服务器,并且希望可以长期维护的话,就需要考虑安全性能与速度等众多因素.一份正确的linux基本安全配置手册就显得格外重要. ...
- Linux服务器的初步配置流程
作者: 阮一峰 日期: 2014年3月14日 开发网站的时候,常常需要自己配置Linux服务器. 本文记录配置Linux服务器的初步流程,也就是系统安装完成后,下一步要做的事情.这主要是我自己的总结和 ...
- linux服务器ntp客户端配置【转】
转自:https://www.cnblogs.com/kerrycode/archive/2015/08/20/4744804.html 在Linux系统中,为了避免主机时间因为在长时间运行下所导致的 ...
- 一台Linux服务器(4C8G配置)可以负载百万个连接?
一台Linux服务器可以负载多少个连接? 首先我们来看如何标识一个TCP连接?系统是通过一个四元组来识别,(src_ip,src_port,dst_ip,dst_port)即源IP.源端口.目标IP. ...
- 拿到新linux服务器,从配置环境到跑起项目的部署流程
今早翻开手机看到某云一条广告Linux1 核 2 GB 1 Mbps服务器10元一个月,正巧最近在搞linux,于是下单了一台2个月20. 上班来到公司后,借空闲时间一顿研究,一波骚操作配置后,浏览器 ...
- Linux 服务器的网络配置 - 1. 查看 Linux 服务器的网络连接
1. 查看 Linux 服务器的网络连接 1)查看主机名: liuqian@ubuntu:~$ hostname ubuntu 2)查看 ip 地址: 用 ifconfig 即可,这里介绍命令组合用法 ...
- Linux服务器静态路由配置
转载自:点击打开链接 静态路由是在路由器中设置的固定的路由表.除非网络管理员干预,否则静态路由不会发生变化.由于静态路由不能对网络的改变作出反映,一般用于网络规模不大.拓扑结构固定的网络中.静态路由的 ...
- Linux 服务器的网络配置 - 2. 查看 Linux 服务器的进程
2. 查看 Linux 服务器的进程 1)ps [主要选项] -a 显示系统中所有进程的信息 -e 显示所有进程的信息 -f 显示进行的所有信息 -l 以长格式显示进程信息 -r 只显示正 ...
- linux服务器的SSH 配置
远程连接服务器: 就是通过文字或图形接口的方式来远程登陆另外一台服务器系统,让你在远程的终端前面登陆linux 主机以取得可操作主机的接口 主要的远程连接服务器的主要类型: 1)文字接口明文传输 : ...
随机推荐
- Python批量重命名 工具贴(一)
说明 由于在处理图片数据和其他数据时,经常需要对数据进行批量重命名操作,每次使用时都需要重写,非常不便,因此记录下重命名代码方便后续使用. 文件结构说明 参数说明: path为输入路径 image_t ...
- go-zero:开箱即用的微服务框架
go-zero 是一个集成了各种工程实践的 Web 和 rpc 框架,它的弹性设计保障了大并发服务端的稳定性,并且已经经过了充分的实战检验. go-zero 在设计时遵循了 "工具大于约定和 ...
- 源码学习之void 0
今天看源码的时候看到 void 0 这样的写法,平时在业务代码里基本没有这样的写法,于是学习了一下. 在控制台运行了一下void 0,得到返回值是undefined. 在MDN上搜了一下void,了解 ...
- 一起来聊聊 IP 地址、局域网、广域网、IPV4 和 IPV6
背景 谁都知道 IP 地址是干嘛的,但是它出现的前因后果你真的知道吗? 我觉得很有必要重新复习下计算机网络基础知识,实在太太太重要了 本篇文章素材均来自:https://www.bilibili.co ...
- redis 客户端实现读写分离实现
背景 (1) redis单机的读写性能轻松上大几万,不过线上环境不会只部署光秃秃的一个节点,还是会配合 sentinel 再部署一个 slave作为高可用节点的: 但是standby的slave节点是 ...
- Unity MVC思想
MVC框架概念MVC全名是Model View Controller,是模型(Model)-视图(View)-控制器(Controller)的缩写,一种软件设计典范,用一种业务逻辑.数据.界面显示分离 ...
- 关于安装运行MYSQL8.0简单使用及注意事项 On Docker Desktop & WSL2
背景介绍 MYSQL是业界非常流行的一款关系型数据库系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性.MySQL所使用的SQL语言是用于访问数据 ...
- 流程自动化RPA,Power Automate Desktop系列 - 发布文档中心
一.背景 内网中有一个基于VuePress搭建的静态文档中心,但是每次修改后都需要重新Build一次才行,之前都是手动执行命令,现在可以基于Power Automate Desktop来创建任务了. ...
- 基于xtrabackup的主从同步
基于xtrabackup的主从同步 作者 刘畅 时间 2020-9-21 服务器版本:CentOS Linux release 7.5.1804 主机名 ip地址 服务器配置 安装软件 密码 mysq ...
- 13、linux中用户和用户组
linux是多用户多进程的系统: 每个文件和进程都需要应对一个用户和用户组: linux系统通过uid和gid来识别用户和组的: 一个用户必须要有唯一的uid和一个主组来识别身份,不同的用户可以使用同 ...