Bir görevde Ansible ile birden fazla dosyayı uzak düğümlere nasıl kopyalayabilirim?
Dosyaları tanımlamak için görevimdeki kopyalama modülü satırını çoğaltmaya çalıştım, ancak yalnızca ilk dosyayı kopyalıyor.
Yanıtlar:
with_fileglob
Döngüyü bunun için kullanabilirsiniz :
- copy:
src: "{{ item }}"
dest: /etc/fooapp/
owner: root
mode: 600
with_fileglob:
- /playbooks/files/fooapp/*
/roles/db/files
ama bu yöntemle çalışmasını sağlayamıyorum. Denedim with_fileglob: - /roles/db/file/*
ama yolu
- 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
değişken olarak set ile sahip olmak mümkün müdür ? { src: 'containerizers', dest: {{ containerizers }} }
.
{ src: '{{ source.var }}', dest: '{{ dest.var }}' }
With_to Together'ı bu amaçla kullanabilirsiniz:
- name: Copy multiple files to multiple directories
copy: src={{ item.0 }} dest={{ item.1 }}
with_together:
- [ 'file1', 'file2', 'file3' ]
- [ '/dir1/', '/dir2/', '/dir3/' ]
Birden fazla konuma ihtiyacınız varsa, birden fazla göreve ihtiyacınız vardır. Bir kopyalama görevi, yalnızca bir konumdan (birden çok dosya dahil) düğümdeki diğerine kopyalayabilir.
- 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'ten bu yana with_*
yapılar kullanımdan kaldırılmıştır ve loop
sözdizimi kullanılmalıdır. Basit bir pratik örnek:
- 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
modülün yalnızca yanıtlanabilir 2.x için çalıştığını, ancak yanıtlanabilir 1.x için çalışmadığını unutmayın
stdout_lines
Dönüş değerinde bahsettiğiniz için cevabınızı düzelttim ancak find
modül için geçerli değil . Sadece bir tane files
, examined
ve matched
dönüş değerleri olarak. Umarım başkalarına yardım eder
find
sadece uzaktaki sisteme bakar, yönetim düğümünden herhangi bir şey almaya izin vermez. Bu cevapların kullanılması with_fileglob
daha uygun görünüyor: 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
İstemci makinenizde birden çok dosyayı kopyalamak için aşağıdaki kaynak kodunu kullanın.
- 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
Not:
Değişken kullanarak birden çok yolu geçiyorsanız
src: "/ root / {{öğe}}"
Farklı öğeler için bir değişken kullanarak yolu geçiyorsanız,
src: "/ root / {{item.source_path}}"
copy
modül, birçok dosyayı ve / veya dizin yapısını kopyalamak için yanlış bir araçtır, synchronize
bunun yerine rsync
arka uç olarak kullanan modülü kullanın . Unutmayın rsync
, hem denetleyiciye hem de hedef ana bilgisayara yüklenmesi gerekir . Gerçekten güçlü, yanıtlanabilir belgeleri kontrol edin .
Örnek - dosyaları build
denetleyicinin dizininden (alt dizinlerle) /var/www/html
hedef ana bilgisayardaki dizine kopyalayın :
synchronize:
src: ./my-static-web-page/build/
dest: /var/www/html
rsync_opts:
- "--chmod=D2755,F644" # copy from windows - force permissions