一、环境和知识预备

  我遇到问题的生产机器是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的双网卡同时上网?的更多相关文章

  1. linux服务器应用NTP配置时间同步

    linux服务器应用NTP配置时间同步 • 为什么建议使用ntpd而不是ntpdate? #####原因很简单,ntpd是步进式的逐渐调整时间,而ntpdate是断点更新,比如现在服务器时间是9.18 ...

  2. linux服务器基本安全配置手册

    转:忘了在哪转的,直接复制到笔记里了,贴出来分享 假如你想要搭建一个Linux服务器,并且希望可以长期维护的话,就需要考虑安全性能与速度等众多因素.一份正确的linux基本安全配置手册就显得格外重要. ...

  3. Linux服务器的初步配置流程

    作者: 阮一峰 日期: 2014年3月14日 开发网站的时候,常常需要自己配置Linux服务器. 本文记录配置Linux服务器的初步流程,也就是系统安装完成后,下一步要做的事情.这主要是我自己的总结和 ...

  4. linux服务器ntp客户端配置【转】

    转自:https://www.cnblogs.com/kerrycode/archive/2015/08/20/4744804.html 在Linux系统中,为了避免主机时间因为在长时间运行下所导致的 ...

  5. 一台Linux服务器(4C8G配置)可以负载百万个连接?

    一台Linux服务器可以负载多少个连接? 首先我们来看如何标识一个TCP连接?系统是通过一个四元组来识别,(src_ip,src_port,dst_ip,dst_port)即源IP.源端口.目标IP. ...

  6. 拿到新linux服务器,从配置环境到跑起项目的部署流程

    今早翻开手机看到某云一条广告Linux1 核 2 GB 1 Mbps服务器10元一个月,正巧最近在搞linux,于是下单了一台2个月20. 上班来到公司后,借空闲时间一顿研究,一波骚操作配置后,浏览器 ...

  7. Linux 服务器的网络配置 - 1. 查看 Linux 服务器的网络连接

    1. 查看 Linux 服务器的网络连接 1)查看主机名: liuqian@ubuntu:~$ hostname ubuntu 2)查看 ip 地址: 用 ifconfig 即可,这里介绍命令组合用法 ...

  8. Linux服务器静态路由配置

    转载自:点击打开链接 静态路由是在路由器中设置的固定的路由表.除非网络管理员干预,否则静态路由不会发生变化.由于静态路由不能对网络的改变作出反映,一般用于网络规模不大.拓扑结构固定的网络中.静态路由的 ...

  9. Linux 服务器的网络配置 - 2. 查看 Linux 服务器的进程

    2. 查看 Linux 服务器的进程 1)ps [主要选项] -a  显示系统中所有进程的信息 -e  显示所有进程的信息 -f  显示进行的所有信息 -l   以长格式显示进程信息 -r  只显示正 ...

  10. linux服务器的SSH 配置

    远程连接服务器: 就是通过文字或图形接口的方式来远程登陆另外一台服务器系统,让你在远程的终端前面登陆linux 主机以取得可操作主机的接口 主要的远程连接服务器的主要类型: 1)文字接口明文传输 : ...

随机推荐

  1. 四、SSL虚拟证书

    沿用练习三,配置基于加密网站的虚拟主机,实现以下目标: 域名为www.c.com 该站点通过https访问 通过私钥.证书对该站点所有数据加密 4.2 方案 源码安装Nginx时必须使用--with- ...

  2. 【渗透实战】sqlmap_修改tamper脚本_绕过WAF_第三期

    /文章作者:Kali_MG1937 CSDN博客号:ALDYS4 QQ:3496925334/ 今天google找注入点的时候发现某企业一个挺有意思的waf 常规操作绕过去后决定写一篇博客 信息收集 ...

  3. asp.net core配合vue实现后端验证码逻辑

    概述 网上的前端验证码逻辑总感觉不安全,验证码建议还是使用后端配合验证. 如果产品确定可以上网的话,就可以使用腾讯,百度等第三方验证,对接方便.但是产品可能内网部署,就必须自己写了. 本文章就是基于这 ...

  4. ffmpeg实战-音视频基础概念

    转发自白狼栈:查看原文 关于音视频,相信大家都看过电影(视频),听过音乐(音频),至少应该都知道mp4是视频文件,mp3是音频文件. 对于一个音视频文件,都有哪些属性呢?以视频为例,我们可以通过 ff ...

  5. conn / as sysdba连接不上

    问题: SQL> conn / as sysdbaERROR:ORA-09817: Write to audit file failed.Linux-x86_64 Error: 28: No s ...

  6. js笔记18

    1.面向对象 (1)单例模式 (2)工厂模式 (3)构造函数 a.类  js天生自带的类 基类   object 子类   Function  Array Number  Math  Boolean ...

  7. 什么IP欺骗?

    1.什么是IP欺骗? IP欺骗是指创建源地址经过修改的Internet协议(IP) 数据包,目的要么是隐藏发送方的身份,要么是冒充其他计算机系统,或者两者兼具.恶意用户往往采用这项技术对目标设备或周边 ...

  8. testt

    一级标题 二级标题 三级标题 四级标题 l 1

  9. 第14章:部署Java网站项目案例

    1 说明 (1) 项目迁移到k8s平台的流程 1) 制作镜像 dockerfile.docker+jenkins持续集成.镜像分类:基础镜像.中间镜像.项目镜像 2) 控制器管理pod 控制器管理po ...

  10. JS replace 替换全部数据

    (1)使用具有全局标志g的正则表达式 var str = "dogdogdog"; var str2 = str.replace(/dog/g,"cat");/ ...