Ubuntu18.04下正确配置网络

NetplanUbuntu 17.10 中引入的一种新的命令行网络配置实用程序,用于在 Ubuntu 系统中轻松管理和配置网络设置。 它允许您使用 YAML 格式的描述文件来抽像化定义网络接口的相关信息。

Netplan 可以使用 NetworkManagerSystemd-networkd 的网络守护程序来做为内核的接口。Netplan 的默认描述文件在 /etc/netplan/*.yaml 里,Netplan 描述文件采用了 YAML 语法。

在 Ubuntu 18.04 中如果再通过原来的 ifupdown 工具包继续在 /etc/network/interfaces 文件里配置管理网络接口是无效的。

本文我们就来讲讲如何使用 Netplan 在 Ubuntu 18.04 中为网络接口配置静态 IP 地址、动态 IP 地址以及 DNS。

Netplan工作原理

Netplan官方网址:https://netplan.io/

Netplan 根据描述文件中定义的内容自动生成其对应的后端网络守护程序所需要的配置信息,后端网络守护程序再根据其配置信息通过Linux 内核管理对应的网络设备。

Ubuntu18.04下正确配置网络插图

使用Networkd配置网络

Systemd-networkd 是一个管理网络设备的系统守护程序, 它能检测并配置网络设备的状态和创建虚拟网络设备。

在进行配置前,我们先来看几个常见配置项的含义。

 
  1. 1. enp0s5 指定需配置网络接口的名称。

  2. 2. dhcp4 是否打开 IPv4 的 dhcp。

  3. 3. dhcp6 是否打开 IPv6 的 dhcp。

  4. 4. addresses 定义网络接口的静态 IP 地址。

  5. 5. gateway4 指定默认网关的 IPv4 地址。

  6. 6. nameservers 指定域名服务器的 IP 地址。

使用Networkd配置动态IP地址

Ubuntu 18.04 Server 安装好后,Netplan 的默认描述文件是:/etc/netplan/50-cloud-init.yaml

  • 修改 Netplan 的描述文件
 
  1. $ sudo vim /etc/netplan/50-cloud-init.yaml

  2. network:

  3. version: 2

  4. renderer: networkd

  5. ethernets:

  6. enp0s5:

  7. dhcp4: yes

  8. dhcp6: yes

  • 运行下面的命令使其生效
$ sudo netplan apply 

使用Networkd配置静态IP地址

  • 修改 Netplan 的描述文件
 
  1. $ sudo vim /etc /netplan / 50 -cloud - init.yaml

  2. network:

  3. renderer: networkd

  4. ethernets:

  5. enp0s5:

  6. addresses:

  7. - 192.168. 100.211 / 23

  8. gateway4: 192.168. 100.1

  9. nameservers:

  10. addresses: [ 8.8. 8.8, 8.8. 4.4]

  11. search: []

  12. optional: true

  13. version: 2

  • 运行下面的命令使配置生效
$ sudo netplan apply 

如果你要增加一个 IPv6 地址,可以在 addresses 行增加。多个地址间用逗号分隔:

 
  1. $ sudo vim /etc/netplan/ 50-cloud-init.yaml

  2. network:

  3. renderer: networkd

  4. ethernets:

  5. enp0s5:

  6. addresses: [ 192.168. 100.211/ 23, 'fe80:0:0:0:0:0:c0a8:64d3']

  7. gateway4: 192.168. 100.1

  8. nameservers:

  9. addresses: [ 8.8. 8.8, 8.8. 4.4]

  10. search: []

  11. optional: true

  12. version: 2

使用Networkd同时配置多张网卡

如果要同时配置多张网卡,只需在Netplan 描述文件中定义多个网络设备就可以了,其它类似。

 
  1. $ sudo vim /etc/netplan/ 50-cloud-init.yaml

  2. # 第一张网卡 enp0s3 配置为动态 IP,第二张网卡 enp0s5 配置为静态 IP。

  3. network:

  4. version: 2

  5. renderer: networkd

  6. ethernets:

  7. enp0s3:

  8. dhcp4: yes

  9. dhcp6: no

  10. enp0s5:

  11. dhcp4: no

  12. dhcp6: no

  13. addresses: [ 192.168 .100 .211/ 23]

  14. gateway4: 192.168 .100 .1

  15. nameservers:

  16. addresses: [ 8.8 .8 .8, 8.8 .4 .4]

使用NetworkManger配置网络

NetworkManager 主要用于在桌面系统上管理网络设备。如果您使用 NetworkManager 作为网络设备管理的系统守护程序,将会使用 NetworkManager 的图形程序来管理网络接口。要使用 NetworkManager,首先需要修改 Netplan 的描述文件:

 
  1. $ sudo vim /etc/netplan/ 50-cloud-init.yaml

  2. network:

  3. version: 2

  4. renderer: NetworkManager

其次是生成NetworkManger对应的配置信息:

 
  1. $ sudo netplan apply

最后就可以打开 Ubuntu 桌面系统上的网络接口图形来管理网络。

其它相关

  • YAML 语言基本语法规则

YAML 语言的设计目标,就是方便人类读写。它实质上是一种通用的数据串行化格式。 YAML 基本语法规则如下

 
  1. 1. 大小写敏感

  2. 2. 使用缩进表示层级关系

  3. 3. 缩进时不允许使用Tab键,只允许使用空格。

  4. 4. 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可

  5. 5. # 表示注释,从这个字符一直到行尾,都会被解析器忽略。

更多的关于 YAML 的使用方法可参考 「 YAML 语言教程 」一文。

  • 根据 Netplan 的描述文件手动创建网络守护程序的配置信息
$ sudo netplan generate 

执行后会使用 /etc/netplan/*.yaml 生成对应网络守护程序的配置信息。例如:

 
  1. $ cat /run/systemd/network/ 10-netplan-enp0s5.network

  2. [ Match]

  3. Name=enp0s5

  4. [ Link]

  5. RequiredForOnline=no

  6. [ Network]

  7. Address= 192.168 .100 .211/ 23

  8. Gateway= 192.168 .100 .1

  9. DNS= 8.8 .8 .8

  10. DNS= 8.8 .4 .4

  • 查看当前系统的 DNS Servers
 
  1. $ systemd -resolve --status

  2. Global

  3. DNSSEC NTA: 10. in -addr.arpa

  4. 16.172. in -addr.arpa

  5. 168.192. in -addr.arpa

  6. 17.172. in -addr.arpa

  7. 18.172. in -addr.arpa

  8. 19.172. in -addr.arpa

  9. 20.172. in -addr.arpa

  10. 21.172. in -addr.arpa

  11. 22.172. in -addr.arpa

  12. 23.172. in -addr.arpa

  13. 24.172. in -addr.arpa

  14. 25.172. in -addr.arpa

  15. 26.172. in -addr.arpa

  16. 27.172. in -addr.arpa

  17. 28.172. in -addr.arpa

  18. 29.172. in -addr.arpa

  19. 30.172. in -addr.arpa

  20. 31.172. in -addr.arpa

  21. corp

  22. d.f.ip6.arpa

  23. home

  24. internal

  25. intranet

  26. lan

  27. local

  28. private

  29. test

  30. Link 2 (enp0s5)

  31. Current Scopes: DNS

  32. LLMNR setting: yes

  33. MulticastDNS setting: no

  34. DNSSEC setting: no

  35. DNSSEC supported: no

  36. DNS Servers: 8.8 .8 .8

  37. 8.8 .4 .4

原文链接:https://blog.csdn.net/weixin_40964777/article/details/124495139

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享