SaltStack @ Aetna

Tehmasp Chaudhri | @tehmaspc

Team Background

  • We are the Aetna (Consumer Digital) Operations team

  • We are an Agile Operations team (currently) consisting of:

    • 3 Site Reliability Engineers (SRE)

    • 2 Cloud Systems Developers (CSD)

    • Product Owner

    • ScrumMaster

    • Director of Operations

  • We build and maintain Utopia, an internal developer platform-as-a-service (PaaS)

  • We employ SaltStack for managing all our infrastructure needs for Utopia (and have been using it for almost a year)

  • We try not to take ourselves too seriously but we're serious about what we do

Why Salt?

  • Speed of execution

  • Flexibility (not as opinionated as other CM tools)

  • Extensibility

  • Environments support

  • No steep learning curve (initial familiarity in team)

  • Salt-Cloud & Salt-API

  • Community & Support

Salt Architecture

  • 2014.7.5 (Helium)

  • Single Salt Master in a management AWS VPC

    • ​could scale out to environment Syndics

  • ~100 Minions currently

  • Environments: {Base, Dev, Stg, Prd, Inf} 

  • Well defined server naming scheme:

    • ​e.g. dev-use1a-pr-01-app-db-0001

Network Topology

Salt Formula Design

  • Every formula in its own repository

  • Use settings.sls to define good defaults as well as Pillar and Grain lookups

  • Use Pillars and Grains consistently across all formulas:

    • ​Pillars for common infrastructure configuration

    • Grains for node (or cluster) specific configuration

  • Documentation

    • Every repo should have a proper README

    • README should describe how to use the formula

    • README should provide admin info (if applicable)

  • Testing

    • Isolate testing setup into .vagrant-salt/

    • Manage dependencies with vagrant-saltdeps

    • Manage integration tests with serverspec

Salt Formula Demo

Environments, Top.sls & Pillars

  • We employ multiple environments in order to allow us to test (breaking) changes:

    • {Base, Dev, Stg, Prd, Inf}

  • ​Our Base environment only includes a single formula, core, which we apply to all minions.

  • Reduce top.sls file changes (for States and Pillars) by templating it out and backing it with a Minion's Grain data

  • Use a separate repository for Pillar data

{%- raw %}
{% set roles = salt['grains.get']('roles', '') %}
{%- if roles %}
{%- endraw %}
{{ env }}:
  'env:{{ env }}':
{%- raw %}
    - match: grain
    {%- for role in roles %}
    - {{ role }}
    {%- endfor %}
{% endif %}
{%- endraw %}

Example Environment top.sls

Salt-Cloud Design

  • Leverage Salt-Cloud for spinning up/down all servers

  • Maintain a separate repository for Salt-Cloud configuration

  • Use our own Python DSL for simplifying Salt Cloud configurations

  • Use Grains extensively to manage Minions

Salt Cloud Demo

Shortcomings with Salt

  • Highly active project which seems to introduce a lot of bugs

  • Salt documentation can be out of sync with actual implementation

  • Salt-Cloud improvements are desired

  • Salt environments can be problematic for some

Future Goals with Salt

  • Salt-API

  • Reactor

  • Enterprise GUI

Questions?

SaltStack @ Aetna

By Tehmasp Chaudhri

SaltStack @ Aetna

SaltStack Deployment @ Aetna

  • 2,506