Cluster SSH (cssh) is a utility that allows you to manage multiple servers over SSH from a single administration console. It was originally designed to work with multiple nodes that make up a HPC (High Performance Computing) cluster. These nodes are usually configured identically, therefore requiring the same administrative command to be run on each node. Using Cluster SSH allows an administrator to type a command into a single console and have it replicated over many systems.
As a SysAdmin this tool can be a huge time saver. In this article we will discuss how to install, configure and use Cluster SSH.
Table of Contents
How to Install Cluster SSH
Cluster SSH is simple to install and available on most Linux distributions. Using your package manager makes installation simple and quick.
Fedora installation of Cluster SSH
sudo dnf install clusterssh -y
CentOS / Red Hat installation of Cluster SSH
sudo yum install clusterssh -y
Ubuntu / Debian installation of Cluster SSH
sudo apt-get install clusterssh
How to Configure Cluster SSH
HPC Cluster Administrators often have very complex configurations that involve several different files, tags, and options. Such a complex configuration is outside the scope of this article (see resources section).
Cluster SSH can be configured through it's global configuration files, or user specific configuration files. Both files use the same format, the only difference is one effects all users and the other is specific to one user. For this tutorial we will be making all changes to the user configurations.
In the interest of keeping this article precise, we will focus on the most popular configurations to quickly get you up and running.
Global Configuration Files
There are three global configuration files. Two are more of map files (like /etc/hosts or /etc/auto.master) than actual configuration files.
- /etc/clusters - Contains a list of tags (cluster names) and the hosts mapped to the specified tag.
- /etc/tags - Reversed logic to /etc/clusters. This allows you to specify one host as a member of multiple tags (clusters).
- /etc/csshrc - This file contains default configuration overrides.
User Specific Configuration Files
There are also three user specific files that directly map to the global files.
- $HOME/.clusterssh/clusters - User specific version of /etc/clusters
- $HOME/.clusterssh/tags - User specific version of /etc/tags
- $HOME/.clusterssh/config - Users specific version of /etc/csshrc
Configure The Clusters File
/etc/clusters (global) or $HOME/.clusterssh/clusters (user specific)
The cluster file format is simply a tag (cluster name) followed by the name of the hosts in said cluster, each separated by a space.
For an example, let's say we have six servers. Two are development servers and four are production servers. We can specify the tag "dev" and then list the development servers. Then do the same for the production servers.
Here is an example clusters file:
# Development servers dev savona@centosdev savona@fenrir # Production Servers prod savona@putorweb1 savona@putorweb2 savona@putorweb3 savona@putorweb4
NOTE: Adding the username (user@host) is optional. You can specify the username on the command line. If you username is the same on all systems you can exclude it entirely.
Now that we have the clusters file created, we can just use the tag to open terminals for the two dev servers listed.
[savona@putor ~]$ cssh dev
The above command would open two XTerm windows, one for each development server listed after the dev tag.
Configuring The Tag File
/etc/tags (global) or $HOME/.clusterssh/tags (user specific)
As stated above, the tag file uses the reverse format of the clusters file. In the tags file, you have a host followed by one or more tags, each separated by a space. This allows for more granular control over the clusters.
In this example, let's say we want to group servers by their OS and location. We could start the line with a host, then list the tags (clusters) that host should be associated with. This allows us to easily specify a single host as a member of several tags (clusters).
Here is an example of seperating our hosts by operating system and location.
savona@putorweb1 centos phila savona@putorweb2 redhat denver savona@putorweb3 redhat phila savona@putorweb4 centos denver
We effectively made the host putorweb1 a member for two clusters. One called centos and the other called phila. We can now connect to all the hosts in the Philadelphia datacenter by using this tag like so:
[savona@putor ~]$ cssh phila Opening to: savona@putorweb1 savona@putorweb3
Likewise, we can also connect to all the CentOS systems using the centos tag:
[savona@putor ~]$ cssh centos Opening to: savona@putorweb1 savona@putorweb4
Cluster SSH Configuration File
/etc/csshrc (global) or $HOME/.clusterssh/config (user specific)
The main configuration file provides a method for overriding the default behavior of the program. The format is similar to the other configuration files, one option and value per line. Here is an example config file:
# Close terminal window after 3 seconds auto_close = 3 # Set initial console position console_position = +0+200 # Hide console menu hide_menu = 1
For a full list of options, see the man page in the resources section.
Basic Usage of Cluster SSH
Using Cluster SHH is simple and can be done with no configuration at all.
As you see in the screenshot above, we logged into two machines by running the following command:
cssh savona@fenrir savona@centosdev
This can also be shortened like so:
cssh -l savona fenrir centosdev
Cluster SSH then opened two XTerm windows, one for each host supplied as arguments. It also opened an administration console in which you type commands that will be duplicated across the XTerm windows.
If you would like to enter something into a specific host only, it is as easy as clicking on that window. You can click back into the administration console to resume sending keystrokes to all terminal windows.
Connecting to Groups of Servers Using Tags
We already touched on using tags (cluster names) in the configuration section. To connect to systems defined in the clusters file or tags file, simply call cssh and the tag name.
[savona@putor ~]$ cssh prod
NOTE: Tags must be configured in either the clusters file or tags file before use. (See Configuring Cluster SSH Above)
Using the Administration Console Options
There are several menu items across the top of the administration console. They hold some useful options that will increase your Cluster SSH efficiency.
In the File menu you will find Show History. It's purpose is obvious, but it's location is very inconspicuous. This will drop a little window down and show you the history of commands typed.
The Hosts menu provides options like "Re-tile Windows" which will re-tile the windows if you moved them, added, or removed hosts. It also has options to make certain windows (or sessions) active or inactive. At the very bottom of this menu there is also a list of currently opened hosts which you can toggle active or inactive. Setting a host to inactive keeps the session open, but anything you type in the admin console will not be sent to that session.
The Send menu allows you to send things like remote host name, username, random number, etc. These items could be different in each session so this simplifies this action. Optionally this menu can be altered by adding a $HOME/.clusterssh/send_menu file.
Using cssh Command Line Options
You can use command line options to further personalize your connections. Here are some popular options:
Specify User on Per Host Basis
You can use the -l (--username) option to specify a user to be used.
cssh -l username host1
This comes in handy when you want to quickly connect to multiple systems using a different user account. Simple supply the basic SSH syntax [username]@[host] multiple times, like so:
cssh savona@putorius ninja@putordb dax@defiant
NOTE: Some clusters or tags file configurations can break this functionality. If it is not working as expected, check your files.
Run Command Upon Login
You can use the -a (--action) option to run a command upon log in. For example, run the who command to see if anyone else is logged in.
cssh -a 'who' host1 host2
Resize Terminal Windows to Fill Screen
You can use the --fillscreen option to resize the windows to use the whole screen.
cssh --fillscreen host1 host2 host3
You can find a full list of command line options by using the links in the resources section below.
Potential for Catastrophes
I learned this lesson the hard way so you don't have to. Because of the way Cluster SSH operates when something goes wrong, it usually goes horribly wrong. Remember you are running commands on multiple systems. That means any mistake, mistype or fat finger is being propagated also.
With great power comes great responsibility.
- Voltaire
Extra special attention should be taken when editing configuration files. Even if you believe the files are the same across all systems, a single comment or blank line can through the line numbers off.
Be careful, double check your typing and configurations before committing. It is easy to get into trouble.
Conclusion
Cluster SSH is an incredibly powerful tool for system administration. Even now as we move on to tools like Puppet and Ansible for configuration management, I still find uses for good ole cssh.
In this article we covered most everything you need to get started. We discussed installing and configuring Cluster SSH as well as some usage examples. If you have a comment, question or horror story we would love to hear it in the comments.
Resources and Links
Leave a Reply Cancel reply
This site uses Akismet to reduce spam. Learn how your comment data is processed.
13 Comments
Join Our Newsletter
Categories
- Bash Scripting (17)
- Basic Commands (50)
- Featured (7)
- Just for Fun (5)
- Linux Quick Tips (98)
- Linux Tutorials (65)
- Miscellaneous (15)
- Network Tools (6)
- Reviews (2)
- Security (32)
This is a bit random but a tool like Ansible does replace these kind of hodpge podge ssh clustering solutions.
We use ansible but I can still think of several use cases for cluster SSH. Great article!
I prefer pdsh personally, but good article
Clustershell is even better if you like pdsh
Securecrt is better one... Anyway these days we have ansible
Secure CRT goes against my values. FOSS!
Hello,
Does cssh allow you to use a Private Key to connect to the target server instead of a password? I don't see an obvious way to do it from the man page.
I don't think there is a way to specify which identify file you want to use like regular ssh (ssh -i /path/to/identity). But, if you have the keys in ~/.ssh/ it will recognize them and use them. In addition you can use host specific configurations in the ~/.ssh/config file. To read more about that see here: https://www.putorius.net/how-to-save-per-user-per-host-ssh-client-settings.html
You can specify it for ssh connection. You could put it in ~/.ssh/config, among many other things, like username for specific hostname or pattern. Cssh just uses regular ssh to connect.
That is a good point, I am going to try this!
Very useful
thanks for your article! if you have any clue of how to replace xterm buy putty it would be fantastic!
thanks
I am not sure what you are asking for help with. Can you be more specific?