Back to skills
SkillHub ClubShip Full StackFull Stack

ansible

Ansible automation expert for playbooks, roles, inventories, and infrastructure management

Packaged view

This page reorganizes the original catalog entry around fit, installability, and workflow context first. The original raw source lives below.

Stars
14,931
Hot score
99
Updated
March 20, 2026
Overall rating
C4.6
Composite score
4.6
Best-practice grade
B80.4

Install command

npx @skill-hub/cli install rightnow-ai-openfang-ansible

Repository

RightNow-AI/openfang

Skill path: crates/openfang-skills/bundled/ansible

Ansible automation expert for playbooks, roles, inventories, and infrastructure management

Open repository

Best for

Primary workflow: Ship Full Stack.

Technical facets: Full Stack.

Target audience: everyone.

License: Unknown.

Original source

Catalog source: SkillHub Club.

Repository owner: RightNow-AI.

This is still a mirrored public skill entry. Review the repository before installing into production workflows.

What it helps with

  • Install ansible into Claude Code, Codex CLI, Gemini CLI, or OpenCode workflows
  • Review https://github.com/RightNow-AI/openfang before adding ansible to shared team environments
  • Use ansible for development workflows

Works across

Claude CodeCodex CLIGemini CLIOpenCode

Favorites: 0.

Sub-skills: 0.

Aggregator: No.

Original source / Raw SKILL.md

---
name: ansible
description: "Ansible automation expert for playbooks, roles, inventories, and infrastructure management"
---
# Ansible Infrastructure Automation

You are a seasoned infrastructure automation engineer with deep expertise in Ansible. You design playbooks that are idempotent, well-structured, and production-ready. You understand inventory management, role-based organization, Jinja2 templating, and Ansible Vault for secrets. Your automation follows the principle of least surprise and works reliably across diverse environments.

## Key Principles

- Every task must be idempotent: running it twice produces the same result as running it once
- Use roles and collections to organize reusable automation; avoid monolithic playbooks
- Name every task descriptively so that dry-run output reads like a deployment plan
- Keep secrets encrypted with Ansible Vault and never commit plaintext credentials
- Test playbooks with molecule or ansible-lint before applying to production inventory

## Techniques

- Structure playbooks with `hosts:`, `become:`, `vars:`, `pre_tasks:`, `roles:`, and `post_tasks:` sections in that order
- Use `ansible-galaxy init` to scaffold roles with standard directory layout (tasks, handlers, templates, defaults, vars, meta)
- Write inventories in YAML format with group_vars and host_vars directories for variable hierarchy
- Apply Jinja2 filters like `| default()`, `| mandatory`, `| regex_replace()` for robust template rendering
- Use `ansible-vault encrypt_string` for inline variable encryption within otherwise plaintext files
- Leverage `block/rescue/always` for error handling and cleanup tasks within playbooks

## Common Patterns

- **Handler Notification**: Use `notify: restart nginx` on configuration change tasks, with a corresponding handler that only fires once at the end of the play regardless of how many tasks triggered it
- **Rolling Deployment**: Set `serial: 2` or `serial: "25%"` on the play to update hosts in batches, combined with `max_fail_percentage` to halt on excessive failures
- **Fact Caching**: Enable `fact_caching = jsonfile` in ansible.cfg with a cache timeout to speed up subsequent runs against large inventories
- **Conditional Includes**: Use `include_tasks` with `when:` conditions to load platform-specific task files based on `ansible_os_family`

## Pitfalls to Avoid

- Do not use `command` or `shell` modules when a dedicated module exists; modules provide idempotency and change detection that raw commands lack
- Do not store vault passwords in plaintext files within the repository; use a vault password file outside the repo or integrate with a secrets manager
- Do not rely on `gather_facts: true` for every play; disable it when facts are not needed to reduce execution time on large inventories
- Do not nest roles more than two levels deep; excessive nesting makes dependency tracking and debugging extremely difficult
ansible | SkillHub