Respostas:
Você pode usar o with_fileglob
loop para isso:
- copy:
src: "{{ item }}"
dest: /etc/fooapp/
owner: root
mode: 600
with_fileglob:
- /playbooks/files/fooapp/*
/roles/db/files
mas não consigo fazê-lo funcionar com este método. Eu tentei, with_fileglob: - /roles/db/file/*
mas não consegui resolver o caminho
- 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
conjunto como variável? { src: 'containerizers', dest: {{ containerizers }} }
.
{ src: '{{ source.var }}', dest: '{{ dest.var }}' }
Você pode usar with_together para esta finalidade:
- name: Copy multiple files to multiple directories
copy: src={{ item.0 }} dest={{ item.1 }}
with_together:
- [ 'file1', 'file2', 'file3' ]
- [ '/dir1/', '/dir2/', '/dir3/' ]
Se você precisar de mais de um local, precisará de mais de uma tarefa. Uma tarefa de cópia pode copiar apenas de um local (incluindo vários arquivos) para outro no nó.
- 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/*
Desde o Ansible 2.5, as with_*
construções estão obsoletas e a loop
sintaxe deve ser usada. Um exemplo prático simples:
- 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
módulo só funciona para ansible 2.x, mas não para ansible 1.x
stdout_lines
no valor de retorno, mas não é aplicável para o find
módulo. Tem apenas files
, examined
e matched
como valores de retorno. Espero que ajude outros
find
só parece olhar para o sistema remoto, não permitindo pegar nada do nó de gerenciamento. Essas respostas, usando with_fileglob
, parecem ser mais adequadas: 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
Use o seguinte código-fonte para copiar vários arquivos em sua máquina cliente.
- 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
Nota:
Se você estiver passando vários caminhos usando a variável, então
src: "/ root / {{item}}"
Se você está passando o caminho usando uma variável para itens diferentes, então
src: "/ root / {{item.source_path}}"
copy
módulo é uma ferramenta errada para copiar muitos arquivos e / ou estrutura de diretório, use o synchronize
módulo que usa rsync
como backend. Lembre-se de que ele requer rsync
instalação no controlador e no host de destino. É realmente poderoso, verifique a documentação do ansible .
Exemplo - copie arquivos do build
diretório (com subdiretórios) do controlador para o /var/www/html
diretório no host de destino:
synchronize:
src: ./my-static-web-page/build/
dest: /var/www/html
rsync_opts:
- "--chmod=D2755,F644" # copy from windows - force permissions