Как я могу скопировать более одного файла на удаленные узлы с помощью Ansible в задаче?
Я попытался продублировать строку модуля копирования в своей задаче для определения файлов, но она копирует только первый файл.
Ответы:
Для этого можно использовать with_fileglob
цикл:
- copy:
src: "{{ item }}"
dest: /etc/fooapp/
owner: root
mode: 600
with_fileglob:
- /playbooks/files/fooapp/*
/roles/db/files
но не могу заставить его работать с этим методом. Я пробовал, with_fileglob: - /roles/db/file/*
но путь не
- name: Your copy task
copy: src={{ item.src }} dest={{ item.dest }}
with_items:
- { src: 'containerizers', dest: '/etc/mesos/containerizers' }
- { src: 'another_file', dest: '/etc/somewhere' }
- { src: 'dynamic', dest: '{{ var_path }}' }
# more files here
dest
набором в качестве переменной? { src: 'containerizers', dest: {{ containerizers }} }
.
{ src: '{{ source.var }}', dest: '{{ dest.var }}' }
Для этого можно использовать with_toght:
- name: Copy multiple files to multiple directories
copy: src={{ item.0 }} dest={{ item.1 }}
with_together:
- [ 'file1', 'file2', 'file3' ]
- [ '/dir1/', '/dir2/', '/dir3/' ]
Если вам нужно более одного места, вам нужно более одной задачи. Одна задача копирования может копировать только из одного места (включая несколько файлов) в другое на узле.
- copy: src=/file1 dest=/destination/file1
- copy: src=/file2 dest=/destination/file2
# copy each file over that matches the given pattern
- copy: src={{ item }} dest=/destination/
with_fileglob:
- /files/*
Начиная с Ansible 2.5 with_*
конструкции устарели , и loop
следует использовать синтаксис. Простой практический пример:
- name: Copy CA files
copy:
src: '{{item}}'
dest: '/etc/pki/ca-trust/source/anchors'
owner: root
group: root
mode: 0644
loop:
- symantec-private.crt
- verisignclass3g2.crt
- hosts: lnx
tasks:
- find: paths="/appl/scripts/inq" recurse=yes patterns="inq.Linux*"
register: file_to_copy
- copy: src={{ item.path }} dest=/usr/local/sbin/
owner: root
mode: 0775
with_items: "{{ files_to_copy.files }}"
find
модуль работает только для ansible 2.x, но не для ansible 1.x
stdout_lines
в возвращаемом значении, но это не применимо для find
модуля. Это только files
, examined
и в matched
качестве возвращаемых значений. Надеюсь, что поможет другим
find
только кажется, что смотрит на удаленную систему, не давая ничего захватить с управляющего узла. Эти ответы с использованием with_fileglob
кажутся более подходящими: stackoverflow.com/a/42290160/272387 , stackoverflow.com/a/36720342/272387 .
- name: find inq.Linux*
find: paths="/appl/scripts/inq" recurse=yes patterns="inq.Linux*"
register: find_files
- name: set fact
set_fact:
all_files:
- "{{ find_files.files | map(attribute='path') | list }}"
when: find_files > 0
- name: copy files
copy:
src: "{{ item }}"
dest: /destination/
with_items: "{{ all_files }}"
when: find_files > 0
Используйте следующий исходный код для копирования нескольких файлов на ваш клиентский компьютер.
- name: Copy data to the client machine
hosts: hostname
become_method: sudo
become_user: root
become: true
tasks:
# Copy twice as sometimes files get skipped (mostly only one file skipped from a folder if the folder does not exist)
- name: Copy UFO-Server
copy:
src: "source files path"
dest: "destination file path"
owner: root
group: root
mode: 0644
backup: yes
ignore_errors: true
Примечание:
Если вы передаете несколько путей с помощью переменной, тогда
SRC: "/ корень / {{элемент}}"
Если вы передаете путь, используя переменную для разных элементов, тогда
src: "/ root / {{item.source_path}}"
copy
module - неправильный инструмент для копирования многих файлов и / или структуры каталогов, используйте synchronize
вместо него модуль, который используется rsync
как бэкэнд. Имейте в виду, это требует rsync
установки как на контроллере, так и на целевом хосте. Это действительно мощно, проверьте доступную документацию .
Пример - копирование файлов из build
каталога (с подкаталогами) контроллера в /var/www/html
каталог на целевом хосте:
synchronize:
src: ./my-static-web-page/build/
dest: /var/www/html
rsync_opts:
- "--chmod=D2755,F644" # copy from windows - force permissions