Відповіді:
Ви можете використовувати 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_together:
- 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: "/ root / {{item}}"
Якщо ви проходите шлях, використовуючи змінну для різних елементів, тоді
src: "/ root / {{item.source_path}}"
copy
Модуль - неправильний інструмент для копіювання багатьох файлів та / або структури каталогів, 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