• Marin Crnković
  • 10+ years of experience
  • work @ web.burza

About me

Problem

  • shared development server
  • two (or more!) guys working on same file
  • first guy to save loses his changes

Solution

  • local development environment
  • light, throwaway VMs using Vagrant
  • configure VM for each project

Provisioning

  • ssh into the box
  • run a couple of commands
  • edit a couple of files
  • run some more commands
  • edit some more files
  • edit some commands
  • run some files

big players

  • Puppet
  • Chef
  • Ansible
  • SaltStack

Saltstack

  • Master
  • Minion
  • Execution modules
  • State modules
  • Pillars
  • Grains

...phew

Master

  • keeps states, pillars and top files
  • talks to minions via ZeroMQ, SSH or RAET

Minions

  • provide data about themselves (Grains)
  • listen for commands from Master
  • run execution modules

Top file

  • describes environments
  • defines set of states per minion
  • pillars have a top file too
# /srv/salt/top.sls
base:
  '*':
    - default
  'db*':
    - mariaDB

development:
  'app*':
    - mailcatcher

production:
  'app*':
    - smtp

State

  • describes state
# Short notation
apache2:
  pkg.installed
# Verbose
install_apache:
  pkg:
    - installed
    - name: apache2


Pillars

  • set of variables for state configuration
  • have own top file

Grains

  • minion environment information
  • OS, disk, RAM, CPU, GPU, ...
  • write your own
  • Config files are YAML
  • ...that are written in Jinja templating language
  • ...and Jinja == Twig
  • Option to use JSON, python, python DSL, pyobjects and more
  • XML is NOT supported. Go, SaltStack!

configuration

# /srv/salt/top.sls
base:
  '*':
    - apache

Top file

Basic example

# /srv/salt/apache.sls OR /srv/salt/apache/init.sls
apache:
  pkg.installed:
    - name: apache2

State configuration

# /srv/pillar/top.sls
base:
  'os:Debian':
    - match: grain
    - debian_packages
  'os:RedHat':
    - match: grain
    - redhat_packages

Pillar top file

Pillars and grains

# /srv/salt/apache.sls
apache:
  pkg.installed:
    - name: {{ pillar['pkgs']['apache'] }}

State configuration

# /srv/pillar/debian_packages.sls
pkgs:
  apache: apache2

# /srv/pillar/redhat_packages.sls
pkgs:
  apache: httpd

Pillars configuration

# /srv/salt/top.sls
base:
  '*':
    - website

Top file

Including and Extending

# /srv/salt/website/init.sls
include:
  - apache.install

extend:
  apache:
    service:
      - running
      - enable: True

Website

# /srv/salt/apache/install.sls
apache:
  pkg.installed:
    - name: {{ salt['pillar.get']('pkgs:apache', 'apache2') }}

Apache

# /srv/salt/nginx/init.sls
nginx:
  pkgrepo:
    - managed
    - name: deb http://nginx.org/packages/ubuntu/ trusty nginx
    - key_url: http://nginx.org/keys/nginx_signing.key

Package repository

Nginx example

  service:
    - running
    - watch:
      - pkg: nginx
      - file: /etc/nginx/nginx.conf

Configure service

  pkg:
    - installed
    - require:
      - pkgrepo: nginx

Install package

/etc/nginx/nginx.conf:
  file:
    - managed
    # /srv/salt/nginx/nginx.conf.jinja
    - source: salt://nginx/nginx.conf.jinja
    - user: root
    - group: root
    - mode: 644
    - template: jinja

Manage file

# /srv/salt/nginx/nginx.conf.jinja
user www-data;
worker_processes {{ 2 * grains['num_cpus'] }};
pid /run/nginx.pid;

Managed file template

Nginx example Continued

master $ salt '*' state.highstate
masterless-minion $ salt-call --local state.highstate
  • Installing and configuring packages is easy
  • So is starting and stopping services
  • And executing commands on remote servers
  • It is also possible to deploy servers in all major
    cloud providers (AWS, Linode, DigitalOcean, Rackspace, ...)

Conclusion

  • Configuration is a bunch of files
  • Version them to roll back server to previous state
  • Or fork the server
    https://github.com/saltstack-formulas

 

 

Conclusion

  • saltstack.com
  • http://docs.saltstack.com/en/latest/index.html
  • https://github.com/saltstack/salt-bootstrap

 

Thank you

Marin Crnković

@anorgan

https://joind.in/13779

 

 

Q/A

SaltStack

By Marin Crnković

SaltStack

  • 3,126