200
云计算
负载均衡
产品简介
产品价格
快速入门
用户指南
实践操作
常见问题
购买指南
云服务器
产品简介
计费规则
购买指导
控制台使用指南
常见问题
云数据库
产品简介
计费规则
购买指导
快速入门
连接实例
控制台使用指南
对象存储
产品简介
控制台使用指南
程序员百科
Python
百度智能云服务器BCC使用教程-怎么配置弹性网卡?

产品推荐:

1、安全稳定的云服务器租用,2核/2G/5M仅37元,点击抢购>>>

2、高防物理服务器20核/16G/50M/500G防御仅350元,点击抢购>>>

3、百度智能建站(五合一网站)仅880元/年,点击抢购>>> 模板建站(PC+手机站)仅480元/年,点击抢购>>>

4、阿里云服务器2核2G3M仅99元/年、2核4G5M仅199元/年,新老同享,点击抢购>>> 

5、腾讯云服务器2核2G4M仅99元/年、新老同享,点击抢购>>>   



点击这里点击这里申请百度智能云特邀VIP帐号,立即体验云服务器BCC>>>


百度智能云服务器BCC使用教程-怎么配置弹性网卡?

根据您的实例使用的镜像不同,部分镜像需要手动配置弹性网卡,才能使绑定在实例上的弹性网卡被系统识别。

前提条件

您已经将弹性网卡绑定到BCC实例上。

准备工作

目前BCC公共镜像默认安装了NetworkManager,NetworkManager 会影响网络设置,特别是路由表。在绑定弹性网卡前,请先登录虚机禁用NetworkManager。

禁用NetworkManager的命令

发行版禁用命令
CentOS 6service NetworkManager stop
chkconfig NetworkManager off
Ubuntu 14 (需要卸载network-manager)service network-manager stop
apt-get --purge remove -y network-manager
Debian 7service network-manager stop
update-rc.d -f network-manager remove
CentOS 7 / Ubuntu 16 / Debian8 / Debian9systemctl stop NetworkManager
systemctl disable NetworkManager

说明:

  • CentOS 8请勿禁用NetworkManager。

弹性网卡配置工具

  • 完成禁用指令且将弹性网卡绑定到BCC实例后,需要根据镜像版本分别执行以下弹性网卡配置才能生效。

    CentOS:bcc_elastic_net_centos_230529.sh

    Ubuntu:bcc_elastic_net_ubuntu_230529.sh

    Debian:bcc_elastic_net_debian.sh

  • Windows系统需要手动配置。

配置工具会创建静态路由,重启网络或者实例后,无需再次进行路由的设置。

运行配置工具

  • 进入创建的BCC服务器,并为配置工具添加可执行权限。
  • 完成挂载弹性网卡操作后,执行配置工具。
  • 对网卡进行修改IP,解绑及重新绑定等操作时,需要再次运行配置工具。

如下所示:

----------------------------------
  Disable NetworkManager.
  Begin to config network...
    create/recreate network config file [OK]
  Begin to create route table...
    add 192.168.32.212 to route table: rt_ens3 [OK]
    add 192.168.32.228 to route table: rt_ens3 [OK]
    add 192.168.32.209 to route table: rt_ens6 [OK]
    add 192.168.32.210 to route table: rt_ens6 [OK]
    add 192.168.32.211 to route table: rt_ens6 [OK]
    add 192.168.32.226 to route table: rt_ens7 [OK]
    add 192.168.32.227 to route table: rt_ens7 [OK]
    add 192.168.32.229 to route table: rt_ens7 [OK]
  Restart network...  [OK]
----------------------------------

配置完成后,可通过ip addr命令查看IP是否已启用(以Centos为例)

[root@instance-h1q92lvr ~]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1400 qdisc pfifo_fast state UP qlen 1000
    link/ether fa:16:3e:7d:2d:ad brd ff:ff:ff:ff:ff:ff
    inet 192.168.32.212/20 brd 192.168.47.255 scope global eth0
    inet 192.168.32.228/20 brd 192.168.47.255 scope global secondary eth0:1
    inet6 fe80::f816:3eff:fe7d:2dad/64 scope link 
       valid_lft forever preferred_lft forever
3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1400 qdisc pfifo_fast state UP qlen 1000
    link/ether fa:16:3e:a6:69:8f brd ff:ff:ff:ff:ff:ff
    inet 192.168.32.209/20 brd 192.168.47.255 scope global eth1
    inet 192.168.32.210/20 brd 192.168.47.255 scope global secondary eth1:1
    inet 192.168.32.211/20 brd 192.168.47.255 scope global secondary eth1:2
    inet6 fe80::f816:3eff:fea6:698f/64 scope link 
       valid_lft forever preferred_lft forever
4: eth2: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1400 qdisc pfifo_fast state UP qlen 1000
    link/ether fa:16:3e:93:e5:44 brd ff:ff:ff:ff:ff:ff
    inet 192.168.32.226/20 brd 192.168.47.255 scope global eth2
    inet 192.168.32.227/20 brd 192.168.47.255 scope global secondary eth2:1
    inet 192.168.32.229/20 brd 192.168.47.255 scope global secondary eth2:2
    inet6 fe80::f816:3eff:fe93:e544/64 scope link 
       valid_lft forever preferred_lft forever

配置弹性网卡

根据BCC实例的操作系统,选择配置弹性网卡的方式:

  • Windows系统配置弹性网卡
  • CentOS系统配置弹性网卡
  • Ubuntu/Debian系统配置弹性网卡

Windows系统配置弹性网卡

准备工作

在给您的Windows系统实例配置弹性网卡前,需要先将弹性网卡绑定在实例上。您可以根据需求在一个弹性网卡上分配一个或多个辅助私网IP地址。通过使用多个私网IP地址,能提高Windows实例高利用率和实现负载故障时的流量转移。

配置方法

以Windows Server 2012R2为例说明Windows系统配置辅助IP的过程。

1.打开网络与共享中心,选择更改适配器设置。

111.png

2.在弹出的页面中选择一个网卡,右键属性。

222.png

3.选择TCP/IPV4,点击属性。

333.png

4.在弹出的对话框中选择“使用下面的ip地址”,这时需要填写ip地址,子网掩码,DNS服务器等信息,这些信息可以通过在命令行下输入命令 ipconfig /all 获取,输完命令或显示很多信息,记下其中的IPv4 Address (IPv4 地址)、Subnet Mask (子网掩码)、Default Gateway (默认网关) 和 DNS Servers (DNS 服务器)这些值。

444.png

5.接下来回到刚才弹出的对话框配置静态ip地址。依次填入获取到的IP地址,子网掩码,默认网关,DNS服务器地址等信息,如下图所示,点击确定,设置过程中会有间断数秒钟的断网,这个是正常现象。

555.png

6.配置好静态IP后,如果您在控制台添加了辅助ip,还需要继续添加辅助ip。

7.在刚才的“Internet协议版本 4 TCP/IP属性”对话框界面点击高级,在弹出的对话框中点击添加,进行添加IP的操作,将在控制台添加的辅助IP依次填写就完成了。

666.png

8.要验证辅助ip确实已添加至操作系统中,可以在命令行下输入ipconfig /all 查看刚才添加的ip是否已经存在。

CentOS系统配置弹性网卡

准备工作

  1. 为防止 cloud-init 重置您的自定义网络配置,请禁用cloud-init中的网络配置,编辑 /etc/cloud/cloud.cfg,添加以下内容。

    network: {config: disabled}

  2. BCC实例中安装了NetworkManager,NetworkManager可能会修改路由设置,因此需要禁用 NetworkManager。
  • CentOS 7 禁用NetworkManager

    systemctl stop NetworkManager
      systemctl disable NetworkManager
  • CentOS 6 禁用NetworkManager

    service NetworkManager stop
      chkconfig NetworkManager off

配置网卡

  1. 获取网络接口名称(网卡名称)
  • BCC实例添加弹性网卡后,可通过以下命令获取弹性网卡的名称。

    ls /sys/class/net
  • 输出结果(示例)

    eth0 eth1 eth2 lo
  • BCC实例默认的主网卡名称为eth0或ens3(部分BCC实例主网卡名为ens3)。以上结果中,添加的弹性网卡为eth1,eth2。
  1. 为弹性网卡创建配置文件,以eth1为例。

    vim /etc/sysconfig/network-scripts/ifcfg-eth1

添加以下内容:

DEVICE=eth1
    BOOTPROTO=dhcp
    ONBOOT=yes
    TYPE=Ethernet
    USERCTL=no
    PEERDNS=no
    IPV6INIT=no
    PERSISTENT_DHCLIENT=yes
    HWADDR=fa:16:3e:6a:14:b5
    DEFROUTE=no

注意:

  • 需要将弹性网卡的MAC地址写入到配置文件中。(可通过cat /sys/class/net/[网卡名称]/address查看弹性网卡的MAC地址)。
  • 为了防止更改默认路由,需要在弹性网卡的配置文件中添加DEFROUTE=no选项。

如果网卡上有多个IP,需要将网卡上的辅助IP添加到配置文件中。

DEVICE=eth1
    BOOTPROTO=dhcp
    ONBOOT=yes
    TYPE=Ethernet
    USERCTL=no
    PEERDNS=no
    IPV6INIT=no
    PERSISTENT_DHCLIENT=yes
    HWADDR=fa:16:3e:6a:14:b5
    DEFROUTE=no
    IPADDR1=192.168.32.210
    PREFIX1=24
    IPADDR2=192.168.32.211
    PREFIX2=24
  1. 重启网络

    systemctl restart network  /  service network restart

配置路由

为了保证数据能够通过正确的网络接口(网卡),您必须为弹性网卡创建新的路由表及规则。

  1. 创建路由表

编辑 /etc/iproute2/rt_tables,分别为每一个弹性网卡创建一个路由表。

10 rt_eth1
    20 rt_eth2
  1. 设置路由规则(以eth1为例)

在终端中运行以下命令:

ip route add default via 192.168.32.1 dev eth1 table rt_eth1

    ip route add 192.168.32.209 dev eth1 table rt_eth1
    ip route add 192.168.32.210 dev eth1 table rt_eth1
    ip route add 192.168.32.211 dev eth1 table rt_eth1

    ip rule add from 192.168.32.209 lookup rt_eth1
    ip rule add from 192.168.32.210 lookup rt_eth1
    ip rule add from 192.168.32.211 lookup rt_eth1

注:

  • 192.168.32.209 / 210 / 211为弹性网卡的IP。
  • 192.168.32.1为弹性网卡的默认网关。

设置完成后,可以通过 ip route show table rt_eth1 查看弹性网卡上每个 IP 的路由。

  1. 创建弹性网卡的静态路由文件(以eth1为例)

为弹性网卡创建静态路由和规则文件,当BCC实例启动或重启网络时都会保留路由和规则,无需再次手动添加。

创建 route-eth1 静态路由文件,vim /etc/sysconfig/network-scripts/route-eth1,添加以下内容:

default via 192.168.32.1 dev eth1 table rt_eth1

    192.168.32.209 dev eth1 table rt_eth1
    192.168.32.210 dev eth1 table rt_eth1
    192.168.32.211 dev eth1 table rt_eth1

创建或编辑 rule-eth1 的规则文件,vim /etc/sysconfig/network-scripts/rule-eth1,添加以下内容:

from 192.168.32.209 lookup rt_eth1
    from 192.168.32.210 lookup rt_eth1
    from 192.168.32.211 lookup rt_eth1

Ubuntu/Debian系统配置弹性网卡

配置前准备工作

  1. 为防止 cloud-init 重置您的自定义网络配置,请禁用cloud-init中的网络配置,编辑 /etc/cloud/cloud.cfg ,添加以下内容:

    network: {config: disabled}
  2. BCC实例中安装了NetworkManager,NetworkManager可能会修改路由设置,因此需要禁用 NetworkManager,并保证系统重启后,NetworkManager仍处于禁用状态。
  • Ubuntu14 需要卸载NetworkManager

    service network-manager stop
      apt-get --purge remove -y network-manager
  • CentOS 6 禁用NetworkManager

    systemctl stop NetworkManager
      systemctl disable NetworkManager

配置网卡

  1. 获取网络接口名称(网卡名称)

BCC实例添加弹性网卡后,可通过以下命令获取弹性网卡的名称。

ls /sys/class/net

输出结果(示例)

eth0 eth1 eht2 lo

BCC实例默认的主网卡名称为eth0或ens3(部分BCC实例主网卡名为ens3)。以上结果中,添加的弹性网卡为eth1,eth2。

  1. 编辑 /etc/network/interfaces

编辑/etc/network/interfaces网络接口文件,修改为以下内容:

auto lo
    iface lo inet loopback
    source /etc/network/interfaces.d/*

对于BCC Ubuntu16实例,编辑 /etc/network/interfaces.d/50-cloud-init.cfg,将其修改为以下内容:

auto ens3
    iface ens3 inet dhcp

同时修改文件名为ens3.cfg

mv /etc/network/interfaces.d/50-cloud-init.cfg  /etc/network/interfaces.d/ens3.cfg

对于BCC Ubuntu20实例,编辑 /etc/netplan/01-netcfg.yaml,将其修改为以下内容:

network:
        version: 2
        renderer: networkd
        ethernets:
            eth0:
                dhcp4: yes
            eth1:
                dhcp4: yes
            eth2:
                dhcp4: yes
  1. 为弹性网卡创建配置文件,以eth1为例。

在/etc/network/interfaces.d/目录下新建eth1.cfg文件

vim /etc/network/interfaces.d/eth1.cfg

添加以下内容:

auto eth1
    iface eth1 inet dhcp
    hwaddress=fa:16:3e:6a:14:b5

注意:

  • 需要将弹性网卡的MAC地址写入到配置文件中。(可通过cat /sys/class/net/[网卡名称]/address查看弹性网卡的MAC地址)。

如果网卡上有多个IP,需要将网卡上的辅助IP添加到配置文件中。

auto eth1
    iface eth1 inet dhcp
    hwaddress=fa:16:3e:6a:14:b5

    iface eth1 inet static
    address 192.168.32.210
    netmask 255.255.240.0

    iface eth1 inet static
    address 192.168.32.211
    netmask 255.255.240.0
  1. 创建 restrict-default-route 文件,以防止默认路由被覆盖。

vim /etc/dhcp/dhclient-enter-hooks.d/restrict-default-route,添加以下内容:

case ${interface} in
      eth0)           #  ubuntu16/debian9为ens3
        ;;
      *)
        unset new_routers
        ;;
    esac
  1. 重启网络。
  • Ubuntu14

    ifdown eth1 && ifup eth1
  • Ubuntu16

    systemctl restart networking
  • Ubuntu20

    netplan apply

配置路由

为了保证数据能够通过正确的网络接口(网卡),您必须为弹性网卡创建新的路由表及规则。

  1. 创建路由表

编辑 /etc/iproute2/rt_tables,分别为每一个弹性网卡创建一个路由表。

10 rt_eth1
    20 rt_eth2
  1. 设置路由规则(以eth1为例)。

在终端中运行以下命令:

ip route add default via 192.168.32.1 dev eth1 table rt_eth1

    ip route add 192.168.32.209 dev eth1 table rt_eth1
    ip route add 192.168.32.210 dev eth1 table rt_eth1
    ip route add 192.168.32.211 dev eth1 table rt_eth1

    ip rule add from 192.168.32.209 lookup rt_eth1
    ip rule add from 192.168.32.210 lookup rt_eth1
    ip rule add from 192.168.32.211 lookup rt_eth1

注:

  • 192.168.32.209 / 210 / 211为弹性网卡的IP
  • 192.168.32.1为弹性网卡的默认网关

设置完成后,可以通过 ip route show table rt_eth1 查看弹性网卡上每个 IP 的路由。

  1. 创建弹性网卡的静态路由文件(以eth1为例)。

编辑/etc/network/interfaces.d/eth1.cfg

auto eth1
    iface eth1 inet dhcp
    hwaddress=fa:16:3e:6a:14:b5

    iface eth1 inet static
    address 192.168.32.210
    netmask 255.255.240.0

    iface eth1 inet static
    address 192.168.32.211
    netmask 255.255.240.0

    # default gateway for eth1
    up ip route add default via 192.168.32.1 dev eth1 table rt_eth0

    # route for every IP
    up ip route add 192.168.32.210 dev eth1 table rt_eth0
    up ip route add 192.168.32.211 dev eth1 table rt_eth0

    # policy rule for every IP
    up ip rule add from 192.168.32.210  lookup rt_eth0
    up ip rule add from 192.168.32.210  lookup rt_eth0


这条帮助是否解决了您的问题? 已解决 未解决

提交成功!非常感谢您的反馈,我们会继续努力做到更好! 很抱歉未能解决您的疑问。我们已收到您的反馈意见,同时会及时作出反馈处理!