Путь к модулю статистики через переменную dict - PullRequest
1 голос
/ 23 февраля 2020

Я хочу зарегистрировать состояние файла с помощью модуля stat , чтобы я мог устанавливать разрешения, если он существует.

В следующих задачах я отправляю переменные в cron и файл модули. Каков хороший способ сделать те же самые переменные доступными для модуля stat, или каков альтернативный метод проверки существования файла на основе dict переменных?

- name: Task One
  cron:
    name: "{{ item.key }} nightly S3 backup"
    minute: "0"
    hour: "12"
    user: "{{ web_user }}"
    job: "cd {{ www_root }}/{{ item.key }}/{{ item.value.current_path | default('current') }}/scripts && ./backup-to-s3.sh > /dev/null 2>&1"
    cron_file: "backup-nightly-{{ item.key | replace('.', '_') }}"
  with_dict: "{{ my_dictionary }}"

- name: Task Two
  stat:
    path: "{{ www_root }}/{{ item.key }}/{{ item.value.current_path | default('current') }}/scripts/backup-to-s3.sh"
    register: stat_result

- name: Task Three
  file:
    path: "{{ www_root }}/{{ item.key }}/{{ item.value.current_path | default('current') }}/scripts/backup-to-s3.sh"
    owner: "{{ web_user }}"
    group: "{{ web_group }}"
    mode: 0755
  when: stat_result.stat.exists == True
  with_dict: "{{ my_dictionary }}"

my_dictionary:
  example.com:
    site_hosts:
      - canonical: example.com
    local_path: ../example.com
    env:
      db_prefix: my_

Я думая, что, возможно, with_items будет хотя бы частью решения.

1 Ответ

1 голос
/ 23 февраля 2020

Q: "Проверить наличие файла на основе переменных dict."

A: Краткий ответ: создать словарь файлов и их статусы. Используйте его в условиях.

Подробности

1) Зарегистрируйте stat_result в l oop

- name: Task Two
  stat:
    path: "{{ www_root }}/{{ item.key }}/{{ item.value.current_path | ...
  register: stat_result
  with_dict: "{{ my_dictionary }}"

2) Создайте словарь

- set_fact:
    files_stat: "{{ dict(stat_result.results|
                    json_query('[].[item.key, stat.exists]')) }}"

3) Использовать словарь в состоянии

- name: Task Three
  file:
    path: "{{ www_root }}/{{ item.key }}/{{ item.value.current_path | ...
    owner: "{{ web_user }}"
    group: "{{ web_group }}"
    mode: 0755
  with_dict: "{{ my_dictionary }}"
  when: files_stat[item.key]


Пример
- hosts: localhost

  vars:
    my_dictionary:
      file1:
        local_path: "find_cpy/file1.ext"
      file2:
        local_path: "find_cpy/file2.ext"
      file3:
        local_path: "find_cpy/file9.ext"

  tasks:
    - stat:
        path: "{{ item.value.local_path }}"
      register: stat_result
      with_dict: "{{ my_dictionary }}"

    - set_fact:
        files_stat: "{{ dict(stat_result.results|
                        json_query('[].[item.key, stat.exists]')) }}"
    - debug:
        var: files_stat

    - file:
        state: file
        mode: "0644"
        path: "{{ item.value.local_path }}"
      with_dict: "{{ my_dictionary }}"
      when: files_stat[item.key]

дать

TASK [debug] ***
ok: [localhost] => {
    "files_stat": {
        "file1": true, 
        "file2": true, 
        "file3": false
    }
}

TASK [file] ***
skipping: [localhost] => (item={'value': {u'local_path': u'find_cpy/file9.ext'}, 'key': u'file3'}) 
ok: [localhost] => (item={'value': {u'local_path': u'find_cpy/file2.ext'}, 'key': u'file2'})
ok: [localhost] => (item={'value': {u'local_path': u'find_cpy/file1.ext'}, 'key': u'file1'})

Q: "json_query требует установки jmespath. Вы бы предложили подход без этого требования? "

A: Приведенная ниже задача создает тот же словарь без json_query.

    - set_fact:
        files_stat: "{{ dict(my_keys|zip(my_stats)) }}"
      vars:
        my_keys: "{{ stat_result.results|map(attribute='item.key')|list }}"
        my_stats: "{{ stat_result.results|map(attribute='stat.exists')|list }}"

См. Объединение элементов из нескольких списков .

...