NAME
App::ClusterSSH - CLI to Net::OpenSSH that runs the same command via SSH on many remote servers at the same time
VERSION
version 0.001
SYNOPSIS
use App::ClusterSSH;
App::ClusterSSH->new_with_options;
DESCRIPTION
Simple application to execute the same remote command across one or more remote servers. This module does *not* handle errors that are generated from remote commands and currently does not log the STDERR of the remote commands that are executed. Any error handling will need to implementing in the calling code.
NAME
App::ClusterSSH
ATTRIBUTES
command
-
command to run on remote servers
config_file
-
Absolute path to YAML configuration file that defines the listing of servers, users, and identity-files. If no config_file is supplied, the default file .app-clusterssh.yml is assumed in the users home directory.
METHODS
run
-
Runs the supplied command (--command <command> or -c <command>) on each remote server. Logging STDOUT to separate files then dumping STDOUT in blocks labelled by the name of the host the STDOUT is from
CONFIGURATION
The follow items are required for *each* server that you wish to run commands on:
identity_file
-
absolute path to the SSH private key to use to connect
user
-
name of user to connect to remote server as
hostname
-
name of remote host
each of these may be defined globally or for each individual server, individual server options take precedence. Global options will be used if any individual options are not listed.
EXAMPLE CONFIGURATIONs
identity_file: "/home/hunter/.ssh/id_rsa"
servers:
- hostname: bastion
user: hunter
identity_file: "/home/hunter/.ssh/bastion_rsa"
- hostname: asphodel
user: hades
or
identity_file: "/home/hunter/.ssh/id_rsa"
user: hunter
servers:
- hostname: bastion
- hostname: asphodel
- hostname: localhost
AUTHOR
Hunter McMillen <mcmillhj@gmail.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Hunter McMillen.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.