ansible 任务委派 delegate_to

时间:2021-07-16
本文章向大家介绍ansible 任务委派 delegate_to,主要包括ansible 任务委派 delegate_to使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

https://www.cnblogs.com/heaven-xi/p/10420087.html

[python@heaven-00 0130]$ cat test20.yml
---
- hosts: local
tasks:
- name: mkdir document /root/test
file:
path: /root/test
state: directory
owner: root
mode: "755"

- name: jiluyi
shell: echo "1" >> /root/a.txt
delegate_to: ansible-04

- name: toush file
file:
path: /root/test/{{ ansible_hostname }}
state: touch
mode: "755"
owner: root

 
 
  # cluster-backup playbook
  # read the guide: 'op/cluster_restore.md'
   
  - hosts:
  - localhost
  tasks:
  # step1: find a healthy member in the etcd cluster
  - name: set NODE_IPS of the etcd cluster
  set_fact: NODE_IPS="{% for host in groups['etcd'] %}{{ host }} {% endfor %}"
   
  - name: get etcd cluster status
  shell: 'for ip in {{ NODE_IPS }};do \
  ETCDCTL_API=3 {{ base_dir }}/bin/etcdctl \
  --endpoints=https://"$ip":2379 \
  --cacert={{ cluster_dir }}/ssl/ca.pem \
  --cert={{ cluster_dir }}/ssl/etcd.pem \
  --key={{ cluster_dir }}/ssl/etcd-key.pem \
  endpoint health; \
  done'
  register: ETCD_CLUSTER_STATUS
  ignore_errors: true
   
  - debug: var="ETCD_CLUSTER_STATUS"
   
  - name: get a running ectd node
  shell: 'echo -e "{{ ETCD_CLUSTER_STATUS.stdout }}" \
  "{{ ETCD_CLUSTER_STATUS.stderr }}" \
  |grep "is healthy"|sed -n "1p"|cut -d: -f2|cut -d/ -f3'
  register: RUNNING_NODE
   
  - debug: var="RUNNING_NODE.stdout"
   
  - name: get current time
  shell: "date +'%Y%m%d%H%M'"
  register: timestamp
   
  # step2: backup data on the healthy member
  - name: make a backup on the etcd node
  shell: "mkdir -p /etcd_backup && cd /etcd_backup && \
  ETCDCTL_API=3 {{ bin_dir }}/etcdctl snapshot save snapshot_{{ timestamp.stdout }}.db"
  args:
  warn: false
  delegate_to: "{{ RUNNING_NODE.stdout }}"
   
  - name: fetch the backup data
  fetch:
  src: /etcd_backup/snapshot_{{ timestamp.stdout }}.db
  dest: "{{ cluster_dir }}/backup/"
  flat: yes
  delegate_to: "{{ RUNNING_NODE.stdout }}"
   
  - name: update the latest backup
  shell: 'cd {{ cluster_dir }}/backup/ && /bin/cp -f snapshot_{{ timestamp.stdout }}.db snapshot.db'

原文地址:https://www.cnblogs.com/cheyunhua/p/15019551.html