Getting Started with Salt - Basic Installation and Setup

Updated by Linode Written by Linode

Contribute on GitHub

Report an Issue | View File | Edit File

Marquee image for Getting Started with Salt - Basic Installation and Setup

Salt is a Python-based configuration management platform designed to control a number of slave servers (called Minions in Salt terminology) from a single master server. This guide walks you through configuring a Salt Master and Minion, and is relevant to any supported Linux distribution.

Before You Begin

  • You will need at least two Linodes: One will function as the Salt Master and the other(s) as Salt Minions.

  • Set each Linode’s hostname. The hostname will be used to identify each Linode within Salt so be specific with their naming (e.g. master, minion1, minion2, etc.).

  • We recommend that you configure private IP addresses for each system if your Linodes are located in the same data center.

Install Using Salt Bootstrap

Salt Bootstrap is a configuration script which automatically detects the operating system it’s running on, sets the correct repositories, and installs Salt. The install script is intended to be run on the Salt master and all minion machines.

Salt Master

curl -L https://bootstrap.saltstack.com -o install_salt.sh
sudo sh install_salt.sh -P -M -N
Note
The -N flag indicates not to install salt-minion, since this system is the Salt master.

Salt Minions

curl -L https://bootstrap.saltstack.com -o install_salt.sh
sudo sh install_salt.sh -P

Coordinate Network Addressing

Salt Master

  1. Uncomment the #interface: line near the top of the file and replace the address placeholder with the address of your Salt master’s Linode. If your Linodes are located in the same data center, you can use the Linode’s private IP address.

    /etc/salt/master
    1
    2
    
    # The address of the interface to bind to:
    interface: 203.0.113.0
  2. Restart Salt:

    sudo systemctl restart salt-master
    

Salt Minions

Note
This step must be performed on each Salt minion.

Uncomment #master: salt near the top of /etc/salt/minion, and replace salt with your Salt master’s IP address:

/etc/salt/minion
1
2
3
# Set the location of the salt master server. If the master server cannot be
# resolved, then the minion will fail to start.
master: 203.0.113.0

Authenticate Minions to the Salt Master

Get Salt Master Key Fingerprint

From the Salt master, list its key fingerprint, and all Minions linked to it with their key fingerprints:

sudo salt-key --finger-all

You should see the minion hostname or IP addresses listed under Unaccepted Keys, and a SHA256 fingerprint of each key. Here the fingerprints are truncated with ... to avoid clutter.

  
Local Keys:
master.pem:  e9:6a:86:bf...
master.pub:  4b:2a:81:79...
Accepted Keys:
Unaccepted Keys:
minion1:  c7:b2:55:83:46...
minion2:  f8:41:ce:73:f8...

Configure Salt Minions

  1. Add the Salt Master’s master.pub fingerprint to /etc/salt/minion, between the single quotes:

    /etc/salt/minion
    1
    2
    3
    4
    
    # Fingerprint of the master public key to validate the identity of your Salt master
    # before the initial key exchange. The master fingerprint can be found by running
    # "salt-key -f master.pub" on the Salt master.
    master_finger: '4b:2a:81:79...'
  2. Restart Salt:

    sudo systemctl restart salt-minion
    
  3. List the Minion’s fingerprint hash and verify it with what’s reported by the Salt Master in Step 1 above:

    sudo salt-call key.finger --local
    

Accept Minions

  1. Once each Minion ID has been verified, accept them all from the Salt Master:

    sudo salt-key -A
    
    Note

    To accept an individual minion, specify it by hostname or IP address:

    sudo salt-key -a hostname
    
  2. Verify the status of accepted minions. The command below should return the hostname or IP address of each Minion which has been verified and is running.

    sudo salt-run manage.up
    

For more information about Salt keys, see the salt-key man page.

Test Master-Minion Connection

Ping all Minions:

sudo salt '*' test.ping

The output should show true for each Minion:

  
root@saltmaster:~# salt '*' test.ping
minion1:
    True
minion2:
    True

Package Management Overview

Packages are installed or removed from Minions using the pkg state module. As long as you’re running a Linux distribution supported by SaltStack, the Salt module controls the distribution’s package manager, be it apt, yum, etc. Packages can be targeted to individual Minions by specifying the minion’s hostname or IP address, or to all Minions by using *.

Install packages using the same package name used in the system repositories of the Salt minion. For example, apache is the Apache httpd server package in Debian and Ubuntu, while httpd is the package name in RHEL-based systems. If your Salt Minions are a version of Debian or Ubuntu, you would install or remove Apache with the examples below.

Install Apache to all Minions:

sudo salt '*' pkg.install apache2

Remove Apache from minion5:

sudo salt 'minion5' pkg.remove apache2

List all packages installed on minion1:

sudo salt 'minion1' pkg.list_pkgs

Services are controlled using the service module.

Restart Apache on all Minions:

sudo salt '*' service.start apache2

View status of the mariadb service on minion1:

sudo salt 'minion1' service.status mariadb

Next Steps

Salt is a complex ecosystem which requires study and practice to thoroughly grasp. The Salt documentation has many examples, tutorials, and reference pages which will help.

Moving forward, you should start by familiarizing yourself with Execution Modules and Salt States, and determine how they can be applied to your setup.

Join our Community

Find answers, ask questions, and help others.

This guide is published under a CC BY-ND 4.0 license.