MultiSSH
Do all the things everywhere at the same time
Installation (gem)
gem install uoregon-multissh
Installation (github)
Clone the repo and install the required gems with bundler
git clone https://github.com/lcrownover/multissh
cd multissh
bundle install
Configuration
On the first run, you'll be prompted to generate a credential file. This file is stored at ~/.ssh/multissh.yaml, with the owner as the current user and mode of 600.
If you decline to generate this file, it will prompt for password if not provided via command line.
If you don't have ssh-agent configured with your keys, it will prompt for a private key password during credential file generation, or during run if you opted out of the credential file.
Usage
Usage: multissh.rb --nodes "server1,server2" --command "echo 'hello'"
--nodes "NODES" REQUIRED: "server1,server2,server3" OR "@nodes.txt"
--command "COMMAND" REQUIRED: "echo 'hello'" OR @command.txt
--username "USERNAME" OPTIONAL: current user by default
--password "PASSWORD" OPTIONAL: will prompt if needed
--pkey_password "PASSWORD" OPTIONAL: will prompt if needed
--block OPTIONAL: block mode for command ouptut
--regenerate_config OPTIONAL: regenerate configuration file
--debug OPTIONAL: debug mode
Examples
Run a command against a comma-separated list of nodes
ruby multissh.rb --nodes "NODE1,NODE2" --command "COMMAND"
Run a command against a file containing a newline-separated list of nodes
node1.example.org
node2.example.org
ruby multissh.rb --nodes @nodes.txt --command "COMMAND"
Run a list of newline-separated commands against a newline-separated list of nodes
echo $(hostname)
yum install ruby
ruby -v
ruby multissh.rb --nodes @nodes.txt --command @commands.txt