Я пишу классификатор внешних узлов для своей инфраструктуры Puppet, и мне нужно управлять /etc/hosts
файл на каждом узле. Следующее (из-за повторяющегося ключа) является недопустимым YAML:
---
host:
name: www1.example.com
host_aliases: www1
ip: 1.2.3.4
host:
name: www2.example.com
host_aliases: www2
ip: 1.2.3.5
я вижу этот связанный ответ, который имеет следующий код:
host {
# Public IPs - eth0
'front-01': ip => '192.168.1.103';
'front-02': ip => '192.168.1.106';
# Private IPs - eth1
'priv0-0': ip => '192.169.40.201';
'priv0-1': ip => '192.169.40.202';
'priv1-0': ip => '192.169.40.207';
'priv1-1': ip => '192.169.40.208';
# Virtual IPs - eth0:1
'vip-01': ip => '192.169.50.202';
'vip-02': ip => '192.169.50.205';
}
Тем не мение,
Наивное предположение было бы таким:
'host':
'www1':
'ip': 1.2.3.4
'www2':
'ip': 1.2.3.5
Но из-за пункта 2 выше, мне неудобно продвигаться вперед в производстве. Тогда мой вопрос:
Где я могу найти документацию по использованию хост-класса таким образом?
Или в противном случае
Как еще я могу управлять несколькими /etc/hosts
записи с ENC?
NB: эти определения используются для быстрой настройки временных многоузловых кластеров в API облачных сервисов для целей разработки и тестирования, поэтому, хотя я не совсем не хочу исследовать решение на основе DNS (или другое альтернативное), управление /etc/hosts
таким образом (если возможно) много более простое решение с гораздо меньшим количеством движущихся частей.
РЕШЕНИЕ: Здесь для справки размещен мой последний код:
class my_hosts(
$hosts = {
'localhost.localdomain' => {
'ensure' => 'present',
'name' => 'localhost.localdomain',
'host_aliases' => 'localhost',
'ip' => '127.0.0.1',
},
},
) {
create_resources host, $hosts
}
И тогда мой ENC YAML выглядит так:
classes:
my_hosts:
hosts:
www1.example.com:
ensure: present
name: www1.example.com
host_aliases: www1
ip: 10.0.0.101
www2.example.com:
ensure: present
name: www2.example.com
host_aliases: www2
ip: 10.0.0.102
объявление 1 и 2:
host {
'front-01': ip => '192.168.1.103';
'front-02': ip => '192.168.1.106';
}
это просто сокращенная запись для
host { 'front-01':
ip => '192.168.1.103',
}
host { 'front-02':
ip => '192.168.1.106',
}
объявление 3:
Когда у вас есть такая запись данных YAML:
custom_hosts:
www1:
ip: 1.2.3.4
www2:
ip: 1.2.3.5
comment: other attributes work also
www3:
name: testserver
ip: 1.2.3.6
вы можете загрузить его в хэш марионетки, а затем создать из него ресурсы
$custom_hosts = hiera('custom_hosts',{})
create_resources(host, $custom_hosts)
Это дает тот же результат, что и:
host { 'www1':
ip => '1.2.3.4',
}
host { 'www2':
ip => '1.2.3.5',
comment => 'other attributes work also',
}
host { 'www3':
name => 'testserver',
ip => '1.2.3.6',
}
Итак, эти строки следует записать в / etc / hosts:
1.2.3.4 www1
1.2.3.5 www2 # other attributes work also
1.2.3.6 testserver