我是ansible的新手,正在探索依赖角色。 documentation link
我没有遇到的文档是 - 在哪里放置requirements.yml
文件。
例如,如果我的site.yml
看起来像这样:
---
- name: prepare system
hosts: all
roles:
- role1
而且,让我们说
通常,ansible-galaxy具有以下结构:
└── test-role
├── defaults
│ └── main.yml
├── files
├── handlers
│ └── main.yml
├── meta
│ └── main.yml
├── README.md
├── tasks
│ └── main.yml
├── templates
├── tests
│ ├── inventory
│ └── test.yml
└── vars
└── main.yml
依赖关系,被添加到meta/main.yml
。假设,role1在此文件中标记了依赖项(对于role2也是如此):
dependencies:
- role: role2
- role: role3
而且,我还有一个requirements.yml
文件,看起来像:
---
- src: some git link1
version: master
name: role2
- src: some git link2
version: master
name: role3
我的问题:我在哪里为role1放置这个requirements.yml
文件?
我了解命令需要安装的要求,
ansible-galaxy install -r requirements.yml -p roles/
而且,我可以为role1执行此操作,但是如何为role2实现自动化?是否需要以这种方式手动解决和安装连续的依赖项,还是有更好的东西?
从技术上讲,只要您在requirements.yml
命令中反映正确的路径,就可以将ansible-galaxy install
文件放在任何您喜欢的位置。
同时,如果您想从Ansible Tower / Awx运行您的剧本,我建议您坚持使用Ansible Tower requirements并将您的requirements.yml
文件放入<project-top-level-directory>/roles/requirements.yml
关于角色之间的依赖关系,ansible-galaxy
能够在安装过程中遇到它们。所以你不需要在你的requirements.yml
中指定所有这些,只需要顶级的。您只需要在每个外部角色中正确指定依赖项。
meta/main.yml
for role1dependencies:
- src: https://my.scm.com/my-ansible-roles/role2.git
scm: git
version: master
name: role2
- src: https://my.scm.com/my-ansible-roles/role3.git
scm: git
version: master
name: role3
meta/main.yml
for role2dependencies:
- src: https://my.scm.com/my-ansible-roles/role4.git
scm: git
version: master
name: role4
- src: https://my.scm.com/my-ansible-roles/role5.git
scm: git
version: master
name: role5
roles/requirements.yml
---
- src: https://my.scm.com/my-ansible-roles/role1.git
scm: git
version: master
name: role1
为了尽可能完整,我现在通常在我的项目中处理本地依赖项以及仅本地/项目角色
ansible-project-dir
└─── roles
| └─── locally-versionned-role1
| └─── locally-versionned-role1
| └─── ...
| └─── requirements.yml
| └─── .gitignore
└─── ansible.cfg
└─── playbook1.yml
└─── playbook2.yml
ansible.cfg
我通过设置roles
强制在本地roles_path = roles
目录中搜索和下载角色,因此用户可以在没有ansible-galaxy install
参数的情况下使用-p
。
roles/requirements.yml
已在上面讨论过。只需将依赖关系列为顶级外部(即未在项目中版本化)作为galaxy角色名称或git uris。如果你需要完全检查这些角色以便以后进行git提交/推送它们,你可以使用ansible-galaxy install -g -f -r roles/requirements
roles/.gitignore
# Ignore everything in roles dir
/*
# Except:
# the .gitignore file
!.gitignore
# the requirements file
!requirements.yml
# Readme if you have one
!README.md
# and any specific role we want to version locally
!locally-versionned-role*/