Luk*_*s B 1 ansible ansible-vault
我对如何使用 ansible 管理多个环境(生产/开发)感到非常困惑。我也在使用molecule进行本地测试。
这是我现在的项目布局。
|----inventories/
| |
| |--dev/
| | |
| | |--group_vars/...
| | |
| | |--host_vars/...
| |
| |--prod/
| |
| |--group_vars/...
| |
| |--host_vars/
| |
| |--my_playbook_hostname_vars.yml
|
|----roles/...
|
|----hosts.yml
|
|----my_playbook.yml
|
Run Code Online (Sandbox Code Playgroud)
这是根据文档的目录结构
现在我有了我的分子文件,我可以像这样链接开发目录
# molecule.yml
provisioner:
name: ansible
inventory:
links:
group_vars: ../../../../inventories/dev/group_vars/
host_vars: ../../../../inventories/dev/host_vars/
Run Code Online (Sandbox Code Playgroud)
因此,Molecule 可以很好地使用 vagrant 驱动程序进行本地测试,例如,我还可以将其设置为使用 EC2 驱动程序在云中进行测试。到目前为止,一切都很好。
但如何启动 my_playbook.yml 呢?当我使用ansible-playbook my_playbook.ymlthen 时,它不知道在哪里寻找变量,因为有两个环境。我怎样才能告诉 Ansible 在 inventory/prod/group_vars 和 inventory/prod/host_vars 下查找,然后通过主机和组名称进一步解析,就像在hosts.yml中定义的那样,而不影响我的分子设置?
当我刚刚在根目录中设置 group_vars/ & host_vars/ 时,它就可以工作
小智 8
根据文件:
-i, --inventory
specify inventory host path or comma separated host list.
Run Code Online (Sandbox Code Playgroud)
一种选择是为每个环境创建一个单独的主机文件(与您提供的文档链接中的方式几乎相同)。像这样:
|-- inventories
| |-- dev
| | |-- group_vars/
| | |-- host_vars/
| | |-- hosts
| |-- prod
| |-- group_vars/
| |-- host_vars/
| |-- hosts
|-- roles/
|-- my_playbook.yml
Run Code Online (Sandbox Code Playgroud)
...然后调用 ansible-playbook-i
ansible-playbook my_playbook.yml -i inventories/dev/hosts
# or
ansible-playbook my_playbook.yml -i inventories/prod/hosts
Run Code Online (Sandbox Code Playgroud)