如何摆脱 Netplan 兔子洞?

如何摆脱 Netplan 兔子洞?

0. 简介

我刚刚Ubuntu 18.04.4 LTS在较旧的 Dell Poweredge 510 上安装了(服务器),以前托管 Windows 2008R2。

安装程序“提到”了网络适配器的问题。该系统有两个 (eno1、eno2) 适配器,它们已绑定到 Windows 服务器中。然而,尽管安装程序抱怨,系统还是成功安装 - 包括功能正常的网络。

作为我的首要任务,我决定解决安装人员对网络的抱怨。我认为将两个适配器绑定起来是个好主意,并仔细阅读了一些文档,了解如何做到这一点。不幸的是,我可能掉进了“Netplan 兔子洞”,所以这个问题是关于如何摆脱它的!以下是我所做的:

1. 编辑文件/etc/cloud/cloud.cfg.d/50-curtin-networking.cfg

以下是我发现的此文件的内容(在任何编辑之前):

network:  
  ethernets:  
eno1:  
  addresses:  
  - 192.168.1.74/24  
  gateway4: 192.168.1.1  
  nameservers:  
    addresses:  
    - 192.168.1.1  
    - 8.8.8.8  
    search:  
    - mylan.local  
  version: 2  

我为上面的文件创建了一个替代品。就是这样:

network:
  version: 2
  ethernets:
    eno1:
      dhcp4: no
    eno2:
      dhcp4: no
      optional: true
  bonds:
    bond0:
      interfaces: [eno1, eno2]
      addresses: [192.168.1.74/24]
      gateway4: 192.168.1.1
      nameservers:
        addresses: [192.168.1.1, 8.8.8.8]
        search: mylan.local
      parameters:
        mode: active-backup
        primary: eno1
        mii-monitor-interval: 100

2. 运行命令检查配置:

$ sudo cloud-init clean
$ sudo cloud-init init
# errors, incl the following: 
...

2020-03-31 04:58:22,849 - util.py[WARNING]: failed stage init  

...

cloudinit.util.ProcessExecutionError: Unexpected error while running command.
Command: ['netplan', 'generate']
Exit code: 1
Reason: -
Stdout: 
Stderr: /etc/netplan/50-cloud-init.yaml:13:15: Error in network definition: bond0: interface 'eno1' is not defined
                    - eno1
                      ^

请注意,stderr 引用的文件是/etc/netplan/50-cloud-init.yaml。但是我没有编辑此文件

好的 - 所以yaml文件显然生成通过我编辑的文件。我决定反对遵循这个建议建议编辑yaml与文件中的信息相反的文件!相反,我选择匆忙撤退!但这似乎也不起作用:

3.撤退!恢复原始.cfg文件:

幸运的是,我保存了原始文件的副本:/etc/cloud/cloud.cfg.d/50-curtin-networking.cfg

我只需将原始文件复制到已编辑的文件上即可将此文件恢复为其原始内容:

$ sudo cp /etc/cloud/cloud.cfg.d/50-curtin-networking_ORIGINAL.cfg /etc/cloud/cloud.cfg.d/50-curtin-networking.cfg

我以为这样可以解决我的问题,但是当我再次运行命令时,我继续收到错误。事实上,我收到的错误与.cfg上面编辑的文件相同!?

$ sudo cloud-init clean
$ sudo cloud-init init
# errors, incl the following: (same errors as above)

4. 问题

此时,我感觉自己就像刚踏入流沙的人一样——我越动,陷得越深。所以,我保持静止,并寻求帮助。我相信 Netplan 一定在某种程度上有效,但那里有很多相互矛盾的信息。

我需要做什么才能将我的网络恢复到其原始安装配置?

Netplan 下网络配置的权威指南在哪里?

答案1

替换 yaml 有错误,搜索:键采用列表而不是单个值,例如:

search: [mylan.local]

如果您修复了这个问题,netplan 生成应该会成功。

至于是否要编辑云配置文件与 netplan yaml 文件,我已经打开https://bugs.launchpad.net/cloud-init/+bug/1869967讨论此问题。目的是用户永远不必在服务器安装上重新运行 cloud-init,并且 /etc/netplan 下的配置文件应被视为要编辑的权威位置。

答案2

这不是答案.这甚至不是一个答案本身,但对于那些发现自己处于Netplan 兔子洞因为他们试图绑定两个以太网,这是如何确认你已经逃脱

$ sudo lshw -class network -short
H/W path            Device      Class      Description
======================================================
/0/100/1/0          eno1        network    NetXtreme II BCM5716 Gigabit Ethernet
/0/100/1/0.1        eno2        network    NetXtreme II BCM5716 Gigabit Ethernet
/1                  bond0       network    Ethernet interface

我还会提醒大家注意运行时生成的错误消息cloud-init init(参见我上面问题中的第 2 项)。显然这些错误消息与实际错误完全无关。我们都习惯了神秘的错误消息,但在我看来,这个消息很阴险,因为它特别抛出了一个红鲱鱼!感谢@slangasek发现这一点。

相关内容