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

Как получить несколько файлов с удаленного компьютера на локальный с помощью Ansible

Я хотел бы скопировать файлы из удаленного каталога в локальный с помощью Ansible, но модуль fetch позволяет мне копировать только один файл. У меня много серверов, с которых мне нужны файлы (один и тот же каталог на каждом сервере), и сейчас я не знаю, как это сделать с помощью Ansible.

Любые идеи?

Вы должны использовать модуль синхронизации сделать это. Это использует потрясающую силу rsync. Он копирует структуры файлов и каталогов любой глубины, является пуленепробиваемым и высокоэффективным - копирует только фактические измененные байты:

- name: Fetch stuff from the remote and save to local
  synchronize:  src={{ item }} dest=/tmp/ mode=pull
  with_items:
    - "folder/one"
    - "folder/two"

Ключ - это mode параметр:

Укажите направление синхронизации. В режиме push источником является локальный хост или делегат; В опрашивающем режиме удаленный хост в контексте является источником.

Вероятно, вам нужно будет зарегистрировать удаленный контент, а затем перебрать его, что-то вроде этого должно работать:

- shell: (cd /remote; find . -maxdepth 1 -type f) | cut -d'/' -f2
  register: files_to_copy

- fetch: src=/remote/{{ item }} dest=/local/
  with_items: "{{ files_to_copy.stdout_lines }}"

где /remote следует изменить с помощью пути к каталогу на вашем удаленном сервере и /local/ с каталогом на вашем хозяине

У меня недостаточно комментариев для комментариев, иначе я бы добавил его.

Я использовал то, что написал Кястутис. мне пришлось внести небольшие изменения

- shell: (cd /remote; find . -maxdepth 1 -type f) | cut -d'/' -f2
  register: files_to_copy

- fetch: src=/remote/{{ item }} dest=/local/
  with_items: "{{ files_to_copy.stdout_lines }}"

With_items - это область, которую мне пришлось изменить. иначе он не смог бы найти файлы.

Исправление примера выше

- hosts: srv-test
  tasks:
    - find: paths="/var/tmp/collect" recurse=no patterns="*.tar"
      register: files_to_copy
    - fetch: src={{ item.path }} dest=/tmp
      with_items: "{{ files_to_copy.files }}"

ну, если вы используете последнюю доступную версию, например 2.9.9, я думаю, нам нужны цитаты для элемента

- name: use find to get the files list which you want to copy/fetch
  find: 
    paths: /etc/
    patterns: ".*passwd$"
    use_regex: True   
  register: file_2_fetch

- name: use fetch to get the files
  fetch:
    src: "{{ item.path }}"
    dest: /tmp/
    flat: yes
  with_items: "{{ file_2_fetch.files }}"

Я подготовил плейбук, который поможет получить отчет о производительности nmon с сервера. Я использовал модуль fetch со ссылкой на вывод модуля оболочки и могу идеально загрузить данные nmon.

---
#NMON PERFORMANCE REPORT FETCH
  - hosts: all
    gather_facts: yes
    become: yes
    vars_prompt:
      - name: "date_input"
        prompt: "Enter date to fetch nmon report (YYMMDD) = "
        private: no

    tasks:
      - pause:
          prompt: "\n\n Enter date to fetch nmon report?\n\n--------------------------------------\n\n1. Fetch nmon:\n2. Exist from Playbook:\n\nPlease select Action: \n--------------------------------------\n"
        register: menu

      - set_fact:
          option: "{{ menu.user_input }}"

      
      - name: Find-out nmon report for given date  {{ inventory_hostname }}
        shell: |
          ls -l /var/nmon/data/* | grep -i {{ date_input }} |awk '{print $NF}'
        register: nmon_files_to_copy
        when: option == "1"

      - name: 'Fetch the NMON Report {{ date_input }} output from server {{ inventory_hostname }}'
        fetch:
          src: "{{ item }}"
          dest: /tmp/
          flat: yes
        with_items: "{{ nmon_files_to_copy.stdout_lines }}"
        when: option == "1"
 
- hosts: srv-test
  tasks:
    - find: paths="/var/tmp/collect" recurse=no patterns="*.tar"
      register: file_to_copy
    - fetch: src={{ item }} dest=/tmp
      with_items: files_to_copy.stdout_lines

Я использую это: 1. Перетащите каталоги с удаленного хоста на определенные хосты.

- name: Gather hosts stats from other hosts
  shell: " scp -r {{results_root_dir_src}} root@{{groups['profiling_server'][0]}}:{{results_root_dir_dest}}/abc/"
  when: "'profiling_server' not in group_names"
#It will not run on the node where the directories need to be copied.
  1. Вытяните каталоги с узла на localhost
- name: Gather from host to local
  delegate_to: 127.0.0.1
  run_once: true
  become: false
  shell: "scp -r root@{{groups['profiling_server'][0]}}:{{results_root_dir}} ./results_local_location "

инвентарь

[nodes]
server1
server2
server3
[profiling_server]
server1