-
-
Notifications
You must be signed in to change notification settings - Fork 32
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inventory plugin filter by tags #115
Comments
Hi @martialblog, So what you already could do is to group instances either by a key or using a group "condition": keyed_groups:
- key: tags.key
prefix: tag_key
separator: ""
groups:
# add hosts to the group development if any of the dictionary's keys or values is the word 'devel'
development: "'devel' in (tags|list)" and use them as hosts target in playbooks:
or
That said, I would be okay in a "filter by tag" PR (since we already have other filters) . |
I also use a generic way of grouping instances by tags like this:
In this case, if your instance had, for example, the tags: docker, monitor and volatile it would get added to the ansible groups grp_docker, grp_monitor and grp_volatile. |
Hi, thanks for the replies. In the particular use case the instances in a tier (production, staging, etc) might be in multiple VPCs and are identified by a tag (key: tier, value: staging). And since I might want to have only the instances in that tier in my inventory, I thought filtering by tag would be the way to go. @resmo In your suggestion I would have to have multiple playbooks if I want to use the same playbook on a different tier. Or I'd have to parameterize the playbook. Right? |
Well, I could probably write a book about "separating tiers" in ansible and cloud environments. Let's say you have 2 tiers, production, staging which contain instances and one inventory file. One thing you could do is to have a generic playbook for hosts in group "cloud" (so no specified tier) which contains all cloud hosts:
and in your playbook run you limit the the hosts to that tier (basically a filter):
inventory cloudstack..yml #...
groups:
cloud: true
keyed_groups:
- prefix: grp
key: tags.groups.split(',') But this can be error prune if you "forget" the So, my solution is to have separate inventories, cloudstack accounts/projects and API keys per tier:
you can even "hardcode" then the a group tier #...
groups:
cloud: true
staging: true and put the api key in a I hope this makes sense. |
Yeah makes sense, that is kinda what is happening here. Different inventory files for different tiers. I don't trust people, including myself, to not forget the The only thing that was missing was a way to differentiate the instances by tags, since other methods (accounts,projects,vpc,etc) couldn't be applied. filter_by_tag seemed like a good solution. |
@martialblog adding support to group by vpc should be straight forward too |
Hi,
First of all, great collection! Works like a charm.
I'm having a use case in which I need to filter the instances by tags.
I quickly hacked something together like this:
Example in the cloudstack-instances.yml
Maybe not ideal yet, just to prototype the idea.
Before I open a PR, is that something you would consider adding?
Cheers
Markus
The text was updated successfully, but these errors were encountered: