Я хотел бы скопировать файлы из удаленного каталога в локальный с помощью 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.
- 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