답변:
아마도 원격 컨텐츠를 등록하고 루프 오버하는 것보다는 다음과 같이 작동해야 할 것입니다.
- 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/
와 마스터의 디렉토리로 변경 해야하는 위치
이렇게하려면 동기화 모듈 을 사용해야합니다 . 이것은 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
매개 변수입니다.
동기화 방향을 지정하십시오. 푸시 모드에서는 localhost 또는 delegate가 소스입니다. 풀 모드에서 컨텍스트의 원격 호스트가 소스입니다.
synchronise
모듈이 훨씬 더 안정적이고 확장 가능한 ansible 파일을 복사하는 다른 방법보다 할 수 있습니다.
나는 그렇지 않으면 그것을 추가 할 의견이 충분하지 않습니다.
나는 Kęstutis가 게시 한 것을 사용했습니다. 나는 약간의 수정을해야했다
- 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는 내가 바꿔야 할 영역이었습니다. 그렇지 않으면 파일을 찾을 수 없습니다.
글쎄, 2.2.1.0과 같은 최신 버전을 사용하고 있다면 항목에 따옴표가 필요하다고 생각합니다.
- 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 }}"
- 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