示例:自动化将目标主机加入到 swarm 集群,成为工作节点
---
- hosts: 192.168.0.10
tasks:
- name: 查看 worker 加入集群的 token
command: docker swarm join-token worker
register: worker_join_token
- name: set facts
set_fact: worker_join_token={{ worker_join_token.stdout.replace('To add a worker to this swarm, run the following command:\n\n ', '').replace('\\\n','') }}
- name: echo
debug: msg={{ worker_join_token }}
- hosts: mongo
tasks:
- name: 加入 swarm 集群
command: "{{ hostvars['192.168.0.10']['worker_join_token'] }}"
ignore_errors: true
- name: 创建 MongoDB 数据卷
command: docker volume create mongo_data
- name: 启动 MongoDB
command: docker run -d -p 27017:27017 --name mongo -v mongo_data:/data/db mongo
原理如下:
- ① 将任务执行的结果注册到变量,此变量的作用域为当前的 playbook
- ② 将变量值做一些额外的处理,设置到 facts 中,facts 中的变量作用域为全局
- ③ 跨主机应用变量 -> 官方文档









网友评论