Отображение выходных данных Ansible playbook в правильном формате

Отображение выходных данных Ansible playbook в правильном формате

Какая конфигурация необходима для правильного форматирования стандартного потокового вывода задач при 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.

Связанный контент