Статическая конфигурация сети Ubuntu 18.04 с cloud-init через Terraform - PullRequest
0 голосов
/ 26 апреля 2019

Я развертываю виртуальные машины Ubuntu 18.04 на VMware vSphere с использованием Terraform, и мне нужно применить некоторые базовые конфигурации, поэтому я использую cloud-init.

Большинство вещей работает правильно (установка имени хоста, добавление пользователей, выполнение команд), но я полностью не могу настроить статический IP-адрес для сетевых интерфейсов.

Я использую стандартных облачных образов Ubuntu , развернутых из их .ova файлов и сразу преобразованных в шаблоны без их включения. Я вижу, что мои данные правильно отображаются в файл из нескольких частей в /var/lib/cloud/instance/user-data.txt.i, но тогда конфигурация сети не применяется.

Я не могу понять, что я делаю неправильно, я даже не знаю, заключается ли проблема в расположении данных (имя файла и тип контента) или в их содержимом. Любая помощь будет оценена.

Это мой код, относящийся к облачному init, в Terraform:

data "template_file" "cloud-config" {
  template = <<YAML
#cloud-config
hostname: ${var.vm_hostname}
# Adds a user called 'example' with the password hash of 'passwort', sudo rights and the default ubuntu groups
users:
  - name: example
    passwd: $6$rounds=4096$P0uvlB9.8nsiY67$uuOxYSk6n/74Ds3JtV1mT6xYjOguwTWgNmOeHvcHiQa9zan57l8dvfHE/zlu19fDmJGySNzLmh6K0R2I1AU9o0
    lock_passwd: false 
    sudo: ALL=(ALL) ALL
    groups: [adm, audio, cdrom, dialout, floppy, video, plugdev, dip, netdev]
runcmd:
  - echo 'This instance was provisioned by Terraform.' >> /etc/motd
  - sed -i s/^PasswordAuthentication\ no\$/PasswordAuthentication\ yes/ /etc/ssh/sshd_config
power_state:
  mode: 'reboot'
  message: 'reboot triggered by cloud-init'
YAML
}

# network-config
data "template_file" "network-config-v2" {
  template = <<YAML
version: 2
ethernets:
  ens192:
    addresses: [${var.vm_ip4address}/${var.vm_ip4subnet}]
    gateway4: ${var.vm_ip4gateway}
YAML
}

data template_cloudinit_config "config" {
  gzip          = true
  base64_encode = true
  part {
    filename     = "init.cfg"
    content_type = "text/cloud-config"
    content      = "${data.template_file.cloud-config.rendered}"
  }
  part {
    filename     = "network-config"
    # also tried text/plain here
    content_type = "text/cloud-config"
    content      = "${data.template_file.network-config-v2.rendered}"
  }
}

resource "vsphere_virtual_machine" "vm" {
  # some details omitted for brevity
  network_interface {
    network_id = "${data.vsphere_network.network.id}"
    adapter_type = "${data.vsphere_virtual_machine.template.network_interface_types[0]}"
  }
  wait_for_guest_net_routable = false
  vapp {
    properties {
      user-data = "${data.template_cloudinit_config.config.rendered}"
    }
  }
}

Это единственные релевантные cloud-init.log строки, которые я смог найти, которые просто говорят, что они возвращаются к конфигурации dhcp по умолчанию:

2019-04-26 13:04:14,373 - __init__.py[DEBUG]: no work necessary for renaming of [['00:50:56:86:ca:38', 'ens192', 'vmxnet3', '0x07b0']]
2019-04-26 13:04:14,375 - stages.py[INFO]: Applying network configuration from fallback bringup=False: {'config': [{'type': 'physical', 'name': 'ens192', 'mac_address': '00:50:56:86:ca:38', 'subnets': [{'type': 'dhcp'}]}], 'version': 1}
2019-04-26 13:04:14,397 - __init__.py[DEBUG]: Selected renderer 'netplan' from priority list: None
2019-04-26 13:04:14,405 - util.py[DEBUG]: Writing to /etc/netplan/50-cloud-init.yaml - wb: [644] 477 bytes

Для чего это стоит, я также безуспешно пытался использовать сетевой конфигурационный формат 1 .

...