Cumin CLI

Cumin CLI - Automation and orchestration framework written in Python

usage: cumin [-h] [-c CONFIG] [--global-timeout GLOBAL_TIMEOUT] [-t TIMEOUT]
             [-m {sync,async}] [-p PCT] [-b BATCH_SIZE] [-s BATCH_SLEEP] [-x]
             [-o {txt,json}] [-i] [--force] [--backend BACKEND]
             [--transport {clustershell}] [--dry-run] [--version] [-d]
             [--trace]
             HOSTS_QUERY [COMMAND [COMMAND ...]]

Positional Arguments

HOSTS_QUERY Hosts selection query
COMMAND Command to be executed. If no commands are specified, --dry-run is set.

Named Arguments

-c, --config configuration file. [default: /etc/cumin/config.yaml]
--global-timeout
 Global timeout in seconds (int) for the whole execution. [default: None (unlimited)]
-t, --timeout Timeout in seconds (int) for the the execution of every command in each host. [default: None (unlimited)]
-m, --mode

Possible choices: sync, async

Execution mode, required when there are multiple COMMANDS to be executed. In sync mode, execute the first command on all hosts, then proceed with the next one only if -p/--success-percentage is reached. In async mode, execute on each host independently from each other, the list of commands, aborting the execution on any given host at the first command that fails.

-p, --success-percentage
 

Possible choices: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100

Percentage threshold to consider an execution unit successful. Required in sync mode, optional in async mode when -b/--batch-size is used. Accepted values are integers in the range 0-100. [default: 100]

-b, --batch-size
 The commands will be executed with a sliding batch of this size. The batch mode depends on the -m/--mode option when multiple commands are specified. In sync mode the first command is executed in batch to all hosts before proceeding with the next one. In async mode all commands are executed on the first batch of hosts, proceeding with the next hosts as soon as one host completes all the commands. The -p/--success-percentage is checked before starting the execution in each host. [default: None (# of hosts)]
-s, --batch-sleep
 Sleep in seconds (float) to wait before starting the execution on the next host when -b/--batch-size is used. [default: None]
-x, --ignore-exit-codes
 USE WITH CAUTION! Treat any executed command as successful, ignoring the exit codes. [default: False]
-o, --output

Possible choices: txt, json

Specify a different output format. [default: None]

-i, --interactive
 Drop into a Python shell with the results. [default: False]
--force USE WITH CAUTION! Force the execution without confirmation of the affected hosts. [default: False]
--backend Override the default backend selected in the configuration file for this execution. The backend-specific configuration must be already present in the configuration file. One of [direct, openstack, puppetdb] or any external backend listed in the configuration file [default: None]
--transport

Possible choices: clustershell

Override the default transport selected in the configuration file for this execution. The transport-specific configuration must already be present in the configuration file. [default: None]

--dry-run Do not execute any command, just return the list of matching hosts and exit. [default: False]
--version show program's version number and exit
-d, --debug Set log level to DEBUG. [default: False]
--trace Set log level to TRACE, a custom logging level intended for development debugging. [default: False]

More details at https://wikitech.wikimedia.org/wiki/Cumin