nodeshell(8) -- Execute command on many nodes in a noderange through ssh ========================================================================= ## SYNOPSIS `nodeshell [options] ` ## DESCRIPTION Allows execution of a command on many nodes in parallel. Like noderun(8), it accepts and interpolates confluent attribute expressions as documented in nodeattribexpressions(5). `nodeshell` provides stdout as stdout and stderr as stderr, unlike psh which combines all stdout and stderr into stdout. ## OPTIONS * `-c COUNT`, `-f COUNT`, `--count=COUNT` Specify the maximum number of instances to run concurrently * `-m MAXNODES`, `--maxnodes=MAXNODES` Specify a maximum number of nodes to run remote ssh command to, prompting if over the threshold * `-n`, `--nonodeprefix` Do not prefix output with node names * `-p PORT`, `--port=PORT` Specify a custom port for ssh * `-s SUBSTITUTION`, `--substitutename=SUBSTITITUTION` Specify a substitution name instead of the nodename. If no {} are in the substitution, it is considered to be an append. For example, '-s -ib' would produce 'node1-ib' from 'node1'. Full expression syntax is supported, in which case the substitution is considered to be the entire new name. {node}-ib would be equivalent to -ib. For example, nodeshell -s {bmc} node1 would ssh to the BMC instead of the node. ## EXAMPLES * Running `echo hi` on for nodes: `# nodeshell n1-n4 echo hi` `n1: hi` `n2: hi` `n3: hi` `n4: hi` * Setting a new static ip address temporarily on secondary interface of four nodes: `# nodeshell n1-n4 ifconfig eth1 172.30.93.{n1}` * If wanting to use literal {} in the command, they must be escaped by doubling: `# nodeshell n1-n4 "ps | awk '{{print $1}}'"` ## SEE ALSO noderun(8)