Какая конфигурация необходима для правильного форматирования стандартного потокового вывода задач при ansible-playbook
запуске Ansible?
То, что я запускаю ansible-playbook foo.yaml
в выводе из задач, включает стандартный поток ( stdout
, stderr
). Но отображение их происходит в большом однострочном блоке JSON, а не печатается как отформатированные строки, которые были отправлены в поток.
TASK [Django: Collect media fixture files] ******************************************************************************
ok: [lorem]
TASK [Django: Create superuser] ******************************************************************************
fatal: [lorem]: FAILED! => {"changed": false, "cmd": "python3 -m django createsuperuser\n --noinput\n --username \"admin\"\n --email \"[email protected]\"", "msg": "\n:stderr: CommandError: You must use --full_name with --noinput.\n", "path": "/var/local/dolor/virtualenv/rectory/venv.py3.7/bin:/usr/local/bin:/usr/bin:/bin:/usr/games", "syspath": ["/tmp/ansible_django_manage_payload_uj9f3le8/ansible_django_manage_payload.zip", "/usr/lib/python37.zip", "/usr/lib/python3.7", "/usr/lib/python3.7/lib-dynload", "/usr/local/lib/python3.7/dist-packages", "/usr/lib/python3/dist-packages"]}
Что является причиной нежелательного форматирования вывода?Как мне указать Ansible всегда правильно форматировать вывод потока для отображения?на ansible-playbook
выходе?
решение1
Ansible по умолчанию использует машиночитаемый JSON-вывод, не подходящий для чтения человеком. Но есть и другиеДоступны модули «обратного вызова», некоторые из которых могут форматировать потоковый вывод.
- Вводящее в заблуждение название
debug
модульбольше подходит для человеческого восприятия. - Недавно,
yaml
модульформатирует вывод потока как удобный для чтения документ YAML.
Итак, используем ANSIBLE_STDOUT_CALLBACK
переменную окружения:
$ ANSIBLE_STDOUT_CALLBACK=yaml ansible-playbook ansible/deploy.yaml
изменит форматирование выходного потока:
[…]
TASK [Django: Collect media fixture files] ******************************************************************************
ok: [lorem]
TASK [Django: Create superuser] ******************************************************************************
fatal: [lorem]: FAILED! => changed=false
cmd: |-
python3 -m django createsuperuser
--noinput
--username "admin"
--email "[email protected]
msg: |-
stderr: |-
CommandError: You must use --full_name with --noinput.
path: "/var/local/dolor/virtualenv/rectory/venv.py3.7/bin:/usr/local/bin:/usr/bin:/bin:/usr/games"
syspath:
- /tmp/ansible_django_manage_payload_uj9f3le8/ansible_django_manage_payload.zip
- /usr/lib/python37.zip
- /usr/lib/python3.7
- /usr/lib/python3.7/lib-dynload
- /usr/local/lib/python3.7/dist-packages
- /usr/lib/python3/dist-packages
решение2
1. Создать файл конфигурации
Чтобы получить вывод Ansible playbook, отформатированный в виде JSON, создайте файл конфигурации:
- либо
ansible.cfg
в том же каталоге, что и файл Ansible playbook - или в домашнем каталоге, начиная с точки,
~/.ansible.cfg
- или в
/etc/ansible/ansible.cfg
Источник:https://docs.ansible.com/ansible/latest/reference_appendices/config.html
Бонус: debug
также дает довольностандартный вывод,stderrисообщение.
Содержимое файла:
[defaults]
stdout_callback=debug
2. Запустите сценарий
Выполните сценарий точно так же, как и раньше.
ansible-playbook foo.yaml
Сравнение
До:
TASK [Django: Collect media fixture files] ******************************************************************************
ok: [lorem]
TASK [Django: Create superuser] ******************************************************************************
fatal: [lorem]: FAILED! => {"changed": false, "cmd": "python3 -m django createsuperuser\n --noinput\n --username \"admin\"\n --email \"[email protected]\"", "msg": "\n:stderr: CommandError: You must use --full_name with --noinput.\n", "path": "/var/local/dolor/virtualenv/rectory/venv.py3.7/bin:/usr/local/bin:/usr/bin:/bin:/usr/games", "syspath": ["/tmp/ansible_django_manage_payload_uj9f3le8/ansible_django_manage_payload.zip", "/usr/lib/python37.zip", "/usr/lib/python3.7", "/usr/lib/python3.7/lib-dynload", "/usr/local/lib/python3.7/dist-packages", "/usr/lib/python3/dist-packages"]}
После:
TASK [Django: Collect media fixture files] ******************************************************************************
ok: [lorem]
TASK [Django: Create superuser] ******************************************************************************
fatal: [lorem]: FAILED! => {
"changed": false,
"cmd": "python3 -m django createsuperuser\n --noinput\n --username \"admin\"\n --email \"[email protected]\"",
"msg": "\n:stderr: CommandError: You must use --full_name with --noinput.\n",
"path": "/var/local/dolor/virtualenv/rectory/venv.py3.7/bin:/usr/local/bin:/usr/bin:/bin:/usr/games",
"syspath": [
"/tmp/ansible_django_manage_payload_uj9f3le8/ansible_django_manage_payload.zip",
"/usr/lib/python37.zip",
"/usr/lib/python3.7",
"/usr/lib/python3.7/lib-dynload",
"/usr/local/lib/python3.7/dist-packages",
"/usr/lib/python3/dist-packages"
]
}
STDERR:
CommandError: You must use --full_name with --noinput.
MSG:
CommandError: You must use --full_name with --noinput.