百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Ubuntu20.04网络配置 和 网卡绑定

off999 2025-02-15 00:41 11 浏览 0 评论

前言

Ubuntu在桌面办公、服务器方面有着不俗的表现,总能够将最新的应用特性囊括其中。

20.04 LTS新功能:

  • 由Canonical提供5年的支持至2025年,ESM扩展支持至2030年。
  • 可在主流平台上运行——x86-64,ARM v7,ARM64,POWER8,POWER9,IBM s390x(LinuxONE),且将引入对RISC-V的基础支持。
  • 为AWS和Azure所定制的云镜像——Ubuntu Pro,包含了安全加固,认证,内核热补丁(Kernel livepatch)以及其他功能。
  • Ubuntu Server Live安装助手现在在联网的情况下自动更新到最新版本并获取最新安全漏洞补丁。提供自动安装的基础支持。
  • SSH支持2次身份认证(2FA)
  • WireGuard?——具有现代加密技术且简单易用的创新VPN技术
  • AppArmor3使系统更安全
  • 更为灵活的bootloader,可容许故障磁盘启动。
  • 在Microsoft Azure上对IPv6的支持更好
  • 支持Amazon Web Services (AWS)最新的Instance Metadata Service(IMDSv2)
  • 长期支持的Linux 5.4内核支持最新的硬件,且包含最新的安全更新。
  • 软件版本更新:QEMU(v4.2), libvirt(v6.0), PHP(v7.4),Ruby(v2.7),GCC(V9.3),Python(v3.8),MySQL(v8.0),NGINX(v1.17)

1.Ubuntu 20.04网络配置

官方文档:https://netplan.io/

Ubuntu从17.04开始,已经放弃在/etc/network/interfaces 里固定IP的配置,而是改成netplan方式,配置文件是:
/etc/netplan/00-installer-config.yaml

1.1 Ubuntu 17.04及之前的静态IP配置方式

~# cat /etc/network/interfaces
root@magedu:~# cat /etc/network/interfaces
# interfaces(5) file used by ifup(8) and ifdown(8)
auto lo
iface lo inet loopback
auto eth0 #?卡?启动,写??要配置IP的实际?卡名称
iface eth0 inet static #配置静态IP,写??要配置IP的实际?卡名称
address 172.18.3.12 #IP地址
netmask 255.255.0.0 #掩码
gateway 172.18.0.1 #?关
dns-nameservers 223.6.6.6 #DNS
dns-nameservers 223.5.5.5
#重启?络服务
~# /etc/init.d/networking restart
~# systemctl restart networking.service

1.2 单网卡静态IP地址

# ubuntu 20.04配置静态IP地址
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      addresses:
      - 10.0.0.70/8
      gateway4: 10.0.0.254
      nameservers:
        addresses:
        - 223.5.5.5
        search:
        - www.chsblogs.com
root@node70:~# netplan apply
set paste #取消vim自动缩进功能

1.3 配置多网卡静态IP

# ubuntu 20.04配置多网卡静态IP地址以及静态路由
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      addresses:
      - 10.0.0.70/8
      gateway4: 10.0.0.254
      nameservers:
        addresses:
        - 223.5.5.5
        search:
        - www.chs.com
    ens38:
      addresses:
      - 172.16.0.70/8
      nameservers:
        addresses:
        - 223.5.5.5
      routes:
        - to: 172.0.0.0/8
          via: 172.0.0.1
        - to: 10.0.0.0/8
          via: 10.0.0.254
root@node70:~# netplan apply

1.4单网卡桥接

# ubuntu 20.04配置单网卡桥接
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      dhcp4: no
      dhcp6: no
  bridges:
    br0:
      dhcp4: no
      dhcp6: no
      addresses: [10.0.0.70/8]
      gateway4: 10.0.0.254
      nameservers:
        addresses: [223.5.5.5]
      interfaces:
        - ens33

1.5 多网卡桥接

# ubuntu 20.04配置单网卡桥接,将br0和br1分别桥接到ens33和ens38
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      dhcp4: no
      dhcp6: no
    ens38:
      dhcp4: no
      dhcp6: no
  bridges:
    br0:
      dhcp4: no
      dhcp6: no
      addresses: [10.0.0.70/8]
      gateway4: 10.0.0.254
      nameservers:
        addresses: [223.5.5.5]
      interfaces:
        - ens33
    br1:
      dhcp4: no
      dhcp6: no
      addresses: [172.0.0.70/8]
      routes:
        - to: 172.0.0.0/8
          via: 172.0.0.1
        - to: 10.0.0.0/8
          via: 10.0.0.254
      interfaces:
        - ens38

1.6 双网卡绑定

# 七种bond模式说明:
第?种模式:mod=0,即:(balance-rr) Round-robin policy(平衡抡循环策略)
特点:传输数据包顺序是依次传输(即:第1个包?eth0,下?个包就?eth1….?直循环下去,直到最后?个传输完毕),此模式提供负载平衡和容错能?。

第?种模式:mod=1,即: (active-backup) Active-backup policy(主-备份策略)
特点:只有?个设备处于活动状态,当?个宕掉另?个?上由备份转换为主设备。mac地址是外部可?得,从外?看来,bond的MAC地址是唯?的,以避免switch(交换机)发?混乱。此模式只提供了容错能?;由此可?此算法的优点是可以提供??络连接的可?性,但是它的资源利?率较低,只有?个接?处于?作状态,在有 N 个?络接?的情况下,资源利?率为1/N。

第三种模式:mod=2,即:(balance-xor) XOR policy(平衡策略)
特点:基于指定的传输HASH策略传输数据包。缺省的策略是:(源MAC地址 XOR ?标MAC地址) % slave数量。其他的传输策略可以通过xmit_hash_policy选项指定,此模式提供负载平衡和容错能?。

第四种模式:mod=3,即:broadcast(?播策略)
特点:在每个slave接?上传输每个数据包,此模式提供了容错能?。

第五种模式:mod=4,即:(802.3ad) IEEE 802.3adDynamic link aggregation(IEEE 802.3ad 动态链接
聚合)
特点:创建?个聚合组,它们共享同样的速率和双?设定。根据802.3ad规范将多个slave?作在同?个激活的聚合体下。
必要条件:
条件1:ethtool?持获取每个slave的速率和双?设定。
条件2:switch(交换机)?持IEEE 802.3ad Dynamic link aggregation。
条件3:?多数switch(交换机)需要经过特定配置才能?持802.3ad模式。

第六种模式:mod=5,即:(balance-tlb) Adaptive transmit load balancing(适配器传输负载均衡)
特点:不需要任何特别的switch(交换机)?持的通道bonding。在每个slave上根据当前的负载(根据速度计算)分配外出流量。如果正在接受数据的slave出故障了,另?个slave接管失败的slave的MAC地址。该模式的必要条件:ethtool?持获取每个slave的速率

第七种模式:mod=6,即:(balance-alb) Adaptive load balancing(适配器适应性负载均衡)
特点:该模式包含了balance-tlb模式,同时加上针对IPV4流量的接收负载均衡(receive load balance,
rlb),?且不需要任何switch(交换机)的?持。
# ubuntu 20.04双网卡绑定配置
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      dhcp4: no
      dhcp6: no
    ens38:
      dhcp4: no
      dhcp6: no
  bonds:
    bond0:
      interfaces:
        - ens33
        - ens38
      addresses: [10.0.0.70/8]
      gateway4: 10.0.0.254
      nameservers:
        addresses: [223.5.5.5]
      parameters:
        mode: active-backup
        mii-monitor-interval: 100

1.7 双网卡绑定 & 桥接

# 网卡绑定用于提供网卡接口冗余以及高可用和端口聚合功能,桥接网卡再给需要桥接设备的服务使用。
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      dhcp4: no
      dhcp6: no
    ens38:
      dhcp4: no
      dhcp6: no
  bonds:
    bond0:
      interfaces:
        - ens33
        - ens38
      #addresses: [10.0.0.70/8]
      #gateway4: 10.0.0.254
      #nameservers:
      #  addresses: [223.5.5.5]
      parameters:
        mode: active-backup
        mii-monitor-interval: 100
  bridges:
    br0:
      dhcp4: no
      dhcp6: no
      addresses: [10.0.0.70/8]
      gateway4: 10.0.0.254
      nameservers:
        addresses: [223.5.5.5]
      interfaces:
        - bond0

1.8 内外多网卡绑定

多网卡情况下实现网卡绑定

root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      dhcp4: no
      dhcp6: no
    ens38:
      dhcp4: no
      dhcp6: no
    ens39:
      dhcp4: no
      dhcp6: no
    ens40:
      dhcp4: no
      dhcp6: no
  bonds:
    bond0:
      interfaces:
        - ens33
        - ens38
      addresses: [10.0.0.70/8]
      gateway4: 10.0.0.254
      nameservers:
        addresses: [223.5.5.5]
      parameters:
        mode: active-backup
        mii-monitor-interval: 100
    bond1:
      interfaces:
        - ens39
        - ens40
      addresses: [172.0.0.70/8]
      gateway4: 172.0.0.1
      nameservers:
        addresses: [223.5.5.5]
      parameters:
        mode: active-backup
        mii-monitor-interval: 100
      routes:
        - to: 10.0.0.0/8
          via: 10.0.0.254
        - to: 172.0.0.0/8
          via: 172.0.0.1

1.9 内网多网卡绑定 & 桥接

root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
  version: 2
  ethernets:
    ens33:
      dhcp4: no
      dhcp6: no
    ens38:
      dhcp4: no
      dhcp6: no
    ens39:
      dhcp4: no
      dhcp6: no
    ens40:
      dhcp4: no
      dhcp6: no
  bonds:
    bond0:
      interfaces:
        - ens33
        - ens38
      parameters:
        mode: active-backup
        mii-monitor-interval: 100
    bond1:
      interfaces:
        - ens39
        - ens40
      parameters:
        mode: active-backup
        mii-monitor-interval: 100
  bridges:
    br0:
      dhcp4: no
      dhcp6: no
      addresses: [10.0.0.70/8]
      gateway4: 10.0.0.254
      nameservers:
        addresses: [223.5.5.5]
      interfaces:
        - bond0
    br1:
      dhcp4: no
      dhcp6: no
      addresses: [172.0.0.70/8]
      gateway4: 172.0.0.1
      nameservers:
        addresses: [223.5.5.5]
      interfaces:
        - bond1
      routes:
        - to: 10.0.0.0/8
          via: 10.0.0.254
        - to: 172.0.0.0/8
          via: 172.0.0.1

1人点赞

运维工作



作者:付宏洲
链接:
https://www.jianshu.com/p/fe3cfadd61f6

来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关推荐

Python进阶教程:如何自定义异常(附电商库存管理案例)

在Python中,你可以使用异常(exceptions)来预期和处理那些干扰程序正常执行流程的错误。Python内置了许多常见的异常,例如ValueError、TypeError和KeyError,但...

Python 中使用try来处理异常的方法

六二,直方大,不习无不利。在学习python中会经常遇到各种异常事件;现归纳一下如何捕捉并处理这些异常;今天来给大家整理一下。一、异常的概念什么是异常?异常即是一个事件,该事件会在程序执行过程中发生,...

python入门-day3:异常处理(异常处理方法及流程python)

异常处理的内容,包括try、except、finally的用法,介绍常见异常类型,最后通过一个练习(处理用户输入的非法数字)帮你把知识点串起来。我会用简单易懂的语言,确保新手也能轻松掌握。Da...

16-Python的异常(python的异常类型及处理)

1-异常介绍1-2-什么是异常异常是程序运行时发生的错误或异常情况,它会中断正常的程序执行流程;Python使用异常处理机制来处理这些运行时错误。1-4-为什么要捕获异常异常会中断程序的执行;1-3-...

Python 异常处理详解(python中异常)

一、什么是异常?核心定义在程序运行过程中,当Python解释器检测到无法继续执行的操作时,会立即创建异常对象并中断当前流程。此时若不处理异常,程序将直接崩溃退出。典型场景与原理用户输入无效数据nu...

掌握这些 Python 异常处理技巧,代码稳如老狗!

在Python中,异常处理不仅可以帮助我们捕获和处理错误,还能让我们更清晰地了解错误发生的背景。1.异常层次结构Python内置了许多异常,我们在编程时可能会经常遇到,例如ZeroDivisi...

python异常处理机制最佳实践(python异常处理总结)

Python异常处理的最佳实践需要兼顾代码健壮性、可读性和性能。以下是经过工程验证的10个核心原则和技巧:一、精准捕获原则避免裸except禁止使用except:或exceptExce...

python之异常处理(python异常处理过程可以概括为三个步骤)

异常语法try:<代码块>except<异常类型>:<代码块>捕获通用异常try:<代码块>exceptExceptionas...

一天学一点,今天学习掌握Python:异常处理与文件操作全攻略

这一笔记记录了我学习python的异常和文件的操作,这也是针对Python异常和文件操作教程的进一步优化建议和注意事项:异常处理优化1.避免过度捕获异常o不要为了捕获异常而捕获异常,应根据实际需求...

新手学Python避坑,学习效率狂飙! 十二、Python 异常处理

异常处理系统分享在Python里,异常指的是程序运行期间出现的错误。当异常发生时,正常的程序流程会被中断,Python会抛出异常对象。为了防止程序因异常而崩溃,你可以使用异常处理机制捕获并处理这...

Python异常处理全攻略:从入门到精通,轻松应对代码“翻车”时刻

喜欢的条友记得关注、点赞、转发、收藏,你们的支持就是我最大的动力源泉。引言:异常处理——代码世界的“保险丝”在编程的世界里,错误和异常就像路上的“坑”,稍不留神就会让你的程序“翻车”。而异常处理,就是...

Python异常处理全面指南(python异常处理步骤)

Python异常处理完全指南异常处理是编写健壮程序的关键技术。Python提供了灵活的语法和丰富的内置异常类型,能够有效管理程序运行时的错误。以下是Python异常处理的全面指南:一、异常处理...

进阶突破python——异常处理机制(异常处理用什么语句python)

Python的异常处理机制是其健壮性设计的核心,通过清晰的语法结构和灵活的处理策略实现错误管理。以下从核心语法、异常对象、高级特性和最佳实践四个维度详解:一、核心语法结构Python使用try-...

Python基础编程——详细介绍Python的异常捕获示例代码

这篇文章主要为大家详细介绍了python的异常捕获,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助①捕捉一个异常捕捉一个异常以用0作为除数会得到Ze...

Python学习 -- 异常捕获技巧(python怎么捕获异常)

在编写Python代码时,异常处理是确保程序稳定性的关键。Python提供了灵活的异常捕获机制,包括try...except语句、try...except...else语句和try...except....

取消回复欢迎 发表评论: