具有多种环境的最佳 Ansible 布局

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)