Назад | Перейти на главную страницу

Puppet Augeas не работает на вставке с линзой и указанным включением

Команда вставки augeas выдает ошибку, если я указываю линзу и включу в ресурсе. Мне не удалось найти никого с подобной проблемой. Когда я включаю следующий ресурс, он выдает бесполезную ошибку, которая просто говорит

$file = "/etc/ldap.conf"
$comment_style = "#comment"
$lens = "Spacevars.lns"
augeas { "${file}":
  context => "/files${file}",
  changes => [
    "ins ${comment_style} before '*[1]'",
    "set ${comment_style}[1] 'Puppet has modified this file with augeas'",
  ],  
  incl => "/files${file}",
  lens => $lens,
}

Я пробовал аналог в augtool:

# augtool --noload --noautoload
augtool> set /augeas/load/Spacevars/lens "Spacevars.lns"
augtool> set /augeas/load/Spacevars/incl "/etc/ldap.conf"
augtool> load
augtool> ins #comment before /files/etc/ldap.conf/*[1]
augtool> set /files/etc/ldap.conf/#comment[1] 'Puppet has modified this file with augeas'
augtool> save
Saved 1 file(s)

Я обнаружил, что без команды вставки он работает нормально (хотя без команды set он ломается даже в augtool, жалующемся на искаженный дочерний узел). Ошибка Puppet при запуске с --debug.

Debug: Augeas[/etc/ldap.conf](provider=augeas): sending command 'ins' with params ["#comment", "before", "/files/etc/ldap.conf/*[1]"]
Debug: Augeas[/etc/ldap.conf](provider=augeas): Closed the augeas connection
Error: /Stage[main]/Augeasdebug/Augeas[/etc/ldap.conf]: Could not evaluate: Error sending command 'ins' with params ["#comment", "before", "/files/etc/ldap.conf/*[1]"]/Error sending command 'ins' with params ["#comment", "before", "/files/etc/ldap.conf/*[1]"]

Без параметров линзы и включения он работает нормально, хотя мне нужно указать их. Я только начинаю использовать augeas, но я не могу найти столько соответствующей документации, используя puppet с augeas. Мне пришлось угадать эквивалентные команды augtool.

В incl параметр принимает путь к файлу в файловой системе, а не в дереве Augeas, поэтому вы должны удалить /files из incl параметр.

Потому что вы положили /files в incl параметр, Augeas не может найти файл для анализа, и ins пытается вставить перед несуществующим путем, что является ошибкой.