При развертывании в vSphere в Automation Assembler можно назначить статический IP-адрес, но нужно быть очень осторожным, чтобы не создать конфликты между командами инициализации cloudConfig и спецификациями настройки.
Примеры проектов
В следующих проектах показано безопасное применение статического IP-адреса без каких-либо конфликтов между командами инициализации облачного шаблона и спецификациями настройки. Все они содержат параметр сети assignment: static
.
Проектирование | Пример кода облачного шаблона |
---|---|
Назначение статического IP-адреса компьютеру Linux без кода cloud-init |
resources: wpnet: type: Cloud.Network properties: name: wpnet networkType: public constraints: - tag: sqa DBTier: type: Cloud.vSphere.Machine properties: flavor: small image: linux-template networks: - name: '${wpnet.name}' assignment: static network: '${resource.wpnet.id}' |
Назначьте статический IP-адрес компьютеру Linux с кодом cloud-init, который не содержит команды назначения сети. ПРИМЕЧАНИЕ. Спецификация настройки vSphere применяется независимо от того, задано ли для свойства customizeGuestOs значение «истина» или данное свойство вообще не используется. |
Пример Ubuntu resources: wpnet: type: Cloud.Network properties: name: wpnet networkType: public constraints: - tag: sqa DBTier: type: Cloud.vSphere.Machine properties: flavor: small image: ubuntu-template customizeGuestOs: true cloudConfig: | #cloud-config ssh_pwauth: yes chpasswd: list: | root:Pa$$w0rd expire: false write_files: - path: /tmpFile.txt content: | ${resource.wpnet.dns} runcmd: - hostnamectl set-hostname --pretty ${self.resourceName} - touch /etc/cloud/cloud-init.disabled networks: - name: '${wpnet.name}' assignment: static network: '${resource.wpnet.id}' Пример CentOS resources: wpnet: type: Cloud.Network properties: name: wpnet networkType: public constraints: - tag: sqa DBTier: type: Cloud.vSphere.Machine properties: flavor: small image: centos-template customizeGuestOs: true cloudConfig: | #cloud-config write_files: - path: /test.txt content: | deploying in power off. then rebooting. networks: - name: '${wpnet.name}' assignment: static network: '${resource.wpnet.id}' |
Назначьте статический IP-адрес компьютеру Linux с кодом cloud-init, который содержит команды назначения сети. Для свойства customizeGuestOs необходимо указать значение «ложь». |
Пример Ubuntu resources: wpnet: type: Cloud.Network properties: name: wpnet networkType: public constraints: - tag: sqa DBTier: type: Cloud.vSphere.Machine properties: flavor: small image: ubuntu-template customizeGuestOs: false cloudConfig: | #cloud-config write_files: - path: /etc/netplan/99-installer-config.yaml content: | network: version: 2 renderer: networkd ethernets: ens160: addresses: - ${resource.DBTier.networks[0].address}/${resource.wpnet.prefixLength} gateway4: ${resource.wpnet.gateway} nameservers: search: ${resource.wpnet.dnsSearchDomains} addresses: ${resource.wpnet.dns} runcmd: - netplan apply - hostnamectl set-hostname --pretty ${self.resourceName} - touch /etc/cloud/cloud-init.disabled networks: - name: '${wpnet.name}' assignment: static network: '${resource.wpnet.id}' Пример CentOS resources: wpnet: type: Cloud.Network properties: name: wpnet networkType: public constraints: - tag: sqa DBTier: type: Cloud.vSphere.Machine properties: flavor: small image: centos-template customizeGuestOs: false cloudConfig: | #cloud-config ssh_pwauth: yes chpasswd: list: | root:VMware1! expire: false runcmd: - nmcli con add type ethernet con-name 'custom ens192' ifname ens192 ip4 ${self.networks[0].address}/${resource.wpnet.prefixLength} gw4 ${resource.wpnet.gateway} - nmcli con mod 'custom ens192' ipv4.dns "${join(resource.wpnet.dns,' ')}" - nmcli con mod 'custom ens192' ipv4.dns-search "${join(resource.wpnet.dnsSearchDomains,',')}" - nmcli con down 'System ens192' ; nmcli con up 'custom ens192' - nmcli con del 'System ens192' - hostnamectl set-hostname --static `dig -x ${self.networks[0].address} +short | cut -d "." -f 1` - hostnamectl set-hostname --pretty ${self.resourceName} - touch /etc/cloud/cloud-init.disabled networks: - name: '${wpnet.name}' assignment: static network: '${resource.wpnet.id}' |
При выполнении развертывания на основе указанного образа назначьте статический IP-адрес компьютеру Linux с кодом cloud-init, который содержит команды назначения сети. Для свойства customizeGuestOs необходимо указать значение «ложь». Кроме того, облачный шаблон не должен содержать свойство ovfProperties, которое блокирует настройку. |
resources: wpnet: type: Cloud.Network properties: name: wpnet networkType: public constraints: - tag: sqa DBTier: type: Cloud.vSphere.Machine properties: flavor: small imageRef: 'https://cloud-images.ubuntu.com/releases/focal/release/ubuntu-20.04-server-cloudimg-amd64.ova' customizeGuestOs: false cloudConfig: | #cloud-config ssh_pwauth: yes chpasswd: list: | root:Pa$$w0rd ubuntu:Pa$$w0rd expire: false write_files: - path: /etc/netplan/99-netcfg-vrac.yaml content: | network: version: 2 renderer: networkd ethernets: ens192: dhcp4: no dhcp6: no addresses: - ${resource.DBTier.networks[0].address}/${resource.wpnet.prefixLength} gateway4: ${resource.wpnet.gateway} nameservers: search: ${resource.wpnet.dnsSearchDomains} addresses: ${resource.wpnet.dns} runcmd: - netplan apply - hostnamectl set-hostname --pretty ${self.resourceName} - touch /etc/cloud/cloud-init.disabled networks: - name: '${wpnet.name}' assignment: static network: '${resource.wpnet.id}' |
Настройка действий по регулярному обслуживанию
По аналогии с первоначальным обслуживанием действие по регулярному обслуживанию также может включать в себя настройку сети. Чтобы пропустить этап настройки при выполнении действий по регулярному обслуживанию, добавьте следующее свойство.
customizeGuestOsDay2: false
Проекты, которые не будут работать или могут привести к нежелательным результатам
- Код cloud-init не содержит команды назначения сети, а свойству customizeGuestOs присвоено значение «ложь».
Для настройки параметров сети нет ни команд инициализации, ни спецификации настройки.
- В коде cloud-init нет команд назначения сети, а для свойства ovfProperties задано значение.
Команды инициализации отсутствуют, но свойство ovfProperties заблокировало спецификацию настройки.
- Код cloud-init содержит команды назначения сети, а свойство customizeGuestOs отсутствует или имеет значение «истина».
Применение спецификации настройки приводит к конфликту с командами инициализации.
Другие решения для cloud-init и спецификаций настройки
При развертывании в vSphere также можно настроить образ преодоления конфликтов между cloud-init и спецификацией настройки. Дополнительные сведения см. в следующем внешнем репозитории.