Managing multiple systems in parallel with SaltStack
Managing Users
If you manage several systems but do not use a directory service, you still might want to manage users centrally. Unsurprisingly, Salt offers a module, pw_user
, that lets you add new users, delete user accounts, and modify individual attributes, such as the home directory [14]; you can even rename existing users. Listing 3 shows how you can create a new user with the user
, rather than the pw_user
, keyword. Before deleting a specific user, you could first list the users on all the systems.
Listing 3
Creating a New User
Note that Salt offers a module (ssh
) to manage the SSH service, so when creating users you can combine modules if you need to generate an SSH key for a new user (ssh-keygen -t rsa
) and roll it out to all the existing systems. The module's documentation [15] demonstrates how that works. If you want to do more than just monitor your systems (e.g., collect status information), take a look at the status
module [16]. Running status.all_status
returns all status data (a lot) for the minion specified. To access the hard disk data in a targeted way, use status.diskusage
, and to check the load status, use status.loadavg
.
If Salt does not offer a module for a functionality of interest, you can simply run shell commands on the systems by using the cmdmod
module [17], which takes the form cmd.<function>
. The cmd.run
pair takes a command you pass in between double or single quotes (Figure 5) and returns the output. Make sure you run the functions from this module with cmd
and not with cmdmod
.
More than Modules
In addition to modules, Salt offers a few commands that cover other functionality. The salt-cp
command, for example, copies data from the master to the minions (Listing 4, first line), allowing you to maintain /etc/hosts
, /etc/motd
, or other configuration files centrally. However, this command was only intended as an emergency solution. Generally, you will be able to manipulate existing files in the most targeted way with the file
module or use the management module for configuration files.
Listing 4
Other SaltStack Commands
The salt-run
command interacts with Salt; for example, it can be used to create a list of unreachable minions:
sudo salt-run manage.down
On Salt, every use of a module is dubbed a job, and salt-run
lets you generate a list of the last jobs (Listing 4, second line). If you would like to see the output of a certain Salt job again, specify the job ID (Listing 4, last line). For the individual commands, salt-run
makes use of its own modules, called "runners" [18].
Conclusions
SaltStack offers almost unlimited system management possibilities because of its large number of integrated modules. Even without the use of in-house configuration management, your computers will be very much under your command, regardless of whether you need to manage users, keep your systems up to date, or just get an overview of particular servers.
Even in heterogeneous networks with Windows machines, you can use Salt. Thanks to its built-in software administration, you can install standard programs like Firefox on Windows clients, and other functions from Linux are also available. Salt proves to be a versatile talent: It makes the use of many tools and DIY scripts redundant.
Infos
- SaltStack project: http://SaltStack.com/community/
- ZeroMQ: http://zeromq.org/
- Windows minions: https://docs.SaltStack.com/en/latest/topics/installation/windows.html
- Supported operating systems: https://docs.SaltStack.com/en/latest/topics/tutorials/salt_bootstrap.html#supported-operating-systems
- Opening ports for Salt: https://docs.SaltStack.com/en/latest/topics/tutorials/firewall.html
test
module: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.test.html- Targeting minions: https://docs.SaltStack.com/en/latest/topics/targeting/
- Defining grains: https://docs.SaltStack.com/en/latest/topics/targeting/grains.html
- Built-in Salt modules: https://docs.SaltStack.com/en/develop/ref/modules/all/index.html
- Writing your own modules: https://docs.SaltStack.com/en/latest/ref/modules/
pkg
module: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.pkg.html- Package module for Apt-based systems: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.aptpkg.html#module-salt.modules.aptpkg
file
module: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.file.html- User management with Salt: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.pw_user.html
- SSH commands: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.ssh.html
status
module: https://docs.SaltStack.com/en/latest/ref/modules/all/salt.modules.status.html- Shell commands with Salt: https://docs.SaltStack.com/en/develop/ref/modules/all/salt.modules.cmdmod.html
- Integrated runner modules: https://docs.SaltStack.com/en/latest/ref/runners/all/index.html
« Previous 1 2 3
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
The Gnome Foundation Struggling to Stay Afloat
The foundation behind the Gnome desktop environment is having to go through some serious belt-tightening due to continued financial problems.
-
Thousands of Linux Servers Infected with Stealth Malware Since 2021
Perfctl is capable of remaining undetected, which makes it dangerous and hard to mitigate.
-
Halcyon Creates Anti-Ransomware Protection for Linux
As more Linux systems are targeted by ransomware, Halcyon is stepping up its protection.
-
Valve and Arch Linux Announce Collaboration
Valve and Arch have come together for two projects that will have a serious impact on the Linux distribution.
-
Hacker Successfully Runs Linux on a CPU from the Early ‘70s
From the office of "Look what I can do," Dmitry Grinberg was able to get Linux running on a processor that was created in 1971.
-
OSI and LPI Form Strategic Alliance
With a goal of strengthening Linux and open source communities, this new alliance aims to nurture the growth of more highly skilled professionals.
-
Fedora 41 Beta Available with Some Interesting Additions
If you're a Fedora fan, you'll be excited to hear the beta version of the latest release is now available for testing and includes plenty of updates.
-
AlmaLinux Unveils New Hardware Certification Process
The AlmaLinux Hardware Certification Program run by the Certification Special Interest Group (SIG) aims to ensure seamless compatibility between AlmaLinux and a wide range of hardware configurations.
-
Wind River Introduces eLxr Pro Linux Solution
eLxr Pro offers an end-to-end Linux solution backed by expert commercial support.
-
Juno Tab 3 Launches with Ubuntu 24.04
Anyone looking for a full-blown Linux tablet need look no further. Juno has released the Tab 3.