Agent skill
podman-orchestration
Install this agent skill to your Project
npx add-skill https://github.com/majiayu000/claude-skill-registry/tree/main/skills/data/podman-orchestration
SKILL.md
What I Do
Guide containerized deployment and orchestration of the crypto-scout ecosystem using Podman Compose.
Service Architecture
┌─────────────────────────────────────────────────────────────────┐
│ crypto-scout-bridge network │
│ │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ crypto-scout │ │ crypto- │ │ crypto- │ │
│ │ -mq │ │ scout-client │ │scout-collector│ │
│ │ (RabbitMQ) │ │ (Collection) │ │(Persistence) │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
│ │ │ │
│ │ ┌──────────────┐ │ │
│ │ │ crypto- │ │ │
│ │ │scout-analyst │ │ │
│ │ │ (Analysis) │ │ │
│ │ └──────────────┘ │ │
│ │ │ │
│ ┌──────┴────────┐ ┌─────────┴───┐ │
│ │ crypto-scout │ │ crypto-scout│ │
│ │-collector-db │ │-collector │ │
│ │ (TimescaleDB) │ │ -backup │ │
│ └───────────────┘ │ (Backups) │ │
│ └─────────────┘ │
└─────────────────────────────────────────────────────────────────┘
Prerequisites
# Install Podman
brew install podman # macOS
sudo apt install podman # Ubuntu
# Install podman-compose
pip3 install podman-compose
# or
brew install podman-compose
# Create network (once)
podman network create crypto-scout-bridge
Service Definitions
crypto-scout-mq (RabbitMQ)
services:
crypto-scout-mq:
image: rabbitmq:4.1.4-management
container_name: crypto-scout-mq
hostname: crypto_scout_mq
ports:
- "127.0.0.1:15672:15672" # Management UI (localhost only)
volumes:
- "./data/rabbitmq:/var/lib/rabbitmq"
- "./rabbitmq/enabled_plugins:/etc/rabbitmq/enabled_plugins:ro"
- "./rabbitmq/rabbitmq.conf:/etc/rabbitmq/rabbitmq.conf:ro"
- "./rabbitmq/definitions.json:/etc/rabbitmq/definitions.json:ro"
env_file:
- ./secret/rabbitmq.env
networks:
- crypto-scout-bridge
healthcheck:
test: ["CMD", "rabbitmq-diagnostics", "-q", "ping"]
interval: 10s
timeout: 5s
retries: 5
start_period: 30s
crypto-scout-collector-db (TimescaleDB)
services:
crypto-scout-collector-db:
image: timescale/timescaledb:latest-pg17
container_name: crypto-scout-collector-db
ports:
- "127.0.0.1:5432:5432"
volumes:
- "./data/postgresql:/var/lib/postgresql/data"
- "./script/init.sql:/docker-entrypoint-initdb.d/00-init.sql:ro"
env_file:
- ./secret/timescaledb.env
networks:
- crypto-scout-bridge
healthcheck:
test: ["CMD-SHELL", "pg_isready -U crypto_scout_db -d crypto_scout"]
interval: 10s
timeout: 5s
retries: 5
start_period: 30s
Container Security Hardening
Standard Security Options
security_opt:
- no-new-privileges=true
cap_drop:
- ALL
read_only: true
tmpfs:
- /tmp:rw,size=512m,mode=1777,nodev,nosuid
init: true
pids_limit: 256
ulimits:
nofile:
soft: 4096
hard: 4096
stop_signal: SIGTERM
stop_grace_period: 30s
restart: unless-stopped
Resource Limits
cpus: "0.5"
mem_limit: "256m"
mem_reservation: "128m"
Management Commands
Start Services
# Start all services
cd crypto-scout-mq && podman-compose up -d
cd crypto-scout-collector && podman-compose up -d
# Start specific service
podman-compose up -d crypto-scout-mq
# Start with build
podman-compose up -d --build
Monitor Services
# View running containers
podman ps
# Check logs
podman logs -f crypto-scout-mq
podman logs -f crypto-scout-client
# Check health status
podman inspect --format='{{.State.Health.Status}}' crypto-scout-mq
# View compose status
podman-compose ps
Stop Services
# Stop all services
podman-compose down
# Stop and remove volumes (destructive)
podman-compose down -v
# Stop specific service
podman-compose stop crypto-scout-client
Secret Management
Environment Files
# crypto-scout-mq/secret/rabbitmq.env
RABBITMQ_ERLANG_COOKIE=strong_random_string
# crypto-scout-collector/secret/timescaledb.env
POSTGRES_DB=crypto_scout
POSTGRES_USER=crypto_scout_db
POSTGRES_PASSWORD=strong_password
# crypto-scout-collector/secret/collector.env
AMQP_RABBITMQ_PASSWORD=mq_password
JDBC_DATASOURCE_PASSWORD=db_password
Secret Setup
# Copy example files
cp secret/rabbitmq.env.example secret/rabbitmq.env
cp secret/timescaledb.env.example secret/timescaledb.env
cp secret/collector.env.example secret/collector.env
# Set permissions
chmod 600 secret/*.env
# Edit with secure values
$EDITOR secret/rabbitmq.env
Network Configuration
External Network
networks:
crypto-scout-bridge:
name: crypto-scout-bridge
external: true
Service Discovery
| Service | Hostname | Ports |
|---|---|---|
| RabbitMQ | crypto-scout-mq | 5672 (AMQP), 5552 (Streams), 15672 (Mgmt) |
| TimescaleDB | crypto-scout-collector-db | 5432 (PostgreSQL) |
| Client | crypto-scout-client | 8081 (HTTP internal) |
| Collector | crypto-scout-collector | 8081 (HTTP internal) |
Troubleshooting
Container Won't Start
# Check logs
podman logs crypto-scout-mq
# Check for port conflicts
lsof -i :5672
lsof -i :5432
# Verify network exists
podman network ls
podman network inspect crypto-scout-bridge
Health Check Failing
# Manual health check
podman exec crypto-scout-mq rabbitmq-diagnostics -q ping
podman exec crypto-scout-collector-db pg_isready -U crypto_scout_db
# Check resource usage
podman stats
Connectivity Issues
# Test network connectivity
podman exec crypto-scout-client ping crypto-scout-mq
podman exec crypto-scout-collector ping crypto-scout-collector-db
# Inspect container network
podman inspect crypto-scout-mq --format='{{.NetworkSettings.Networks}}'
When to Use Me
Use this skill when:
- Setting up the development environment
- Deploying services to production
- Configuring container security
- Managing secrets and environment variables
- Troubleshooting container issues
- Scaling or modifying service configurations
- Setting up CI/CD pipelines with Podman
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
agent-ops-spec
Manage specification documents in .agent/specs/. Use when user provides requirements, acceptance criteria, or feature descriptions that need to be tracked and validated against implementation.
agent-ops-state
Maintain .agent state files. Use at session start, after meaningful steps, and before concluding: read/update constitution/memory/focus/issues/baseline consistently.
agent-ops-spec
Manage specification documents in .agent/specs/. Use when user provides requirements, acceptance criteria, or feature descriptions that need to be tracked and validated against implementation.
agent-ops-testing
Test strategy, execution, and coverage analysis. Use when designing tests, running test suites, or analyzing test results beyond baseline checks.
agent-ops-testing
Test strategy, execution, and coverage analysis. Use when designing tests, running test suites, or analyzing test results beyond baseline checks.
agent-ops-state
Maintain .agent state files. Use at session start, after meaningful steps, and before concluding: read/update constitution/memory/focus/issues/baseline consistently.
Didn't find tool you were looking for?