CLI
AIS CLI is the Swiss‑army knife for managing and monitoring every aspect of an AIStore cluster’s lifecycle — from initial bootstrap to day‑to-day operations, and from single-object I/O to distributed ML workflows.
In addition, CLI provides dataset management commands, performance monitoring, advanced operations, and more.
The entire (diverse and growing) command set is partitioned into top-level namespaces:
$ ais <TAB-TAB>
advanced         config           get              object           scrub            tls
alias            cp               help             performance      search           wait
archive          create           job              prefetch         show
auth             download         log              put              space-cleanup
blob-download    dsort            ls               remote-cluster   start
bucket           etl              ml               rmb              stop
cluster          evict            mpu              rmo              storage
CLI namespaces
Hit <TAB> after typing ais  and Bash/Zsh completion reveals namespaces — self‑contained toolboxes such as
bucket, cluster, etl, performance, or ml namespace (introduced in v3.30), and so on.
Drill into any namespace with <TAB> and --help to discover its verbs, flags, and usage examples.
ais show
Given an existing AIS instance, maybe the very first command you run would be ais show cluster. For example:
$ ais show cluster
PROXY            MEM USED(%)     MEM AVAIL       LOAD AVERAGE    UPTIME          K8s POD         STATUS
p[DlPmJiRU]      0.01%           366.36GiB       [0.1 0.3 0.3]   526h28m20s      ais-proxy-5     online
p[JedAkLgG][P]   0.02%           366.52GiB       [0.7 0.3 0.3]   526h27m30s      ais-proxy-7     online
...
TARGET         MEM USED(%)     MEM AVAIL     CAP USED(%)   CAP AVAIL     LOAD AVERAGE    REBALANCE     UPTIME        K8s POD         STATUS
t[KoplySra]    0.03%           366.37GiB     52%           8.324TiB      [0.1 0.3 0.3]   -             526h26m10s    ais-target-1    online
...
Summary:
   Proxies:             10 (all electable)
   Targets:             10 (total disks: 30)
   Cluster Map:         version 760, UUID HCGGmT4K0, primary p[JedAkLgG]
   Deployment:          K8s
   Status:              20 online
   Rebalance:           n/a
   Authentication:      ...
   Version:             ...
   Build:               ...
Press
to see all `ais show` subcommands: $ ais show <TAB> auth bucket performance rebalance remote-cluster log etl object cluster storage config job tls
Next, monitoring-wise, you’d maybe run ais show performance, etc.
Table of contents
- Getting Started
- CLI Reference
- CLI Config
- Environment variables
- First steps
- Global options
- Backend Provider
- Verbose errors
- CLI Help Paging
AIS command-line interface (CLI) is a tool to easily manage and monitor every aspect of the AIS clusters’ lifecycle.
In addition, CLI provides dataset management commands, reading and writing primitives, and more.
Getting Started
To build CLI from the source, run the following two steps:
$ make cli			# 1. build CLI binary and install it into your `$GOPATH/bin` directory
$ make cli-autocompletions	# 2. install CLI autocompletions (Bash or Zsh)
To build with debug, run:
$ MODE=debug make cli
Alternatively, install directly from GitHub:
For example, the following command extracts CLI binary to the specified destination and, secondly, installs bash autocompletions:
$ ./scripts/install_from_binaries.sh --dstdir /tmp/www --completions
For more usage options, run: ./scripts/install_from_binaries.sh --help
You can also install bash and/or zsh autocompletions separately at any (later) time:
To uninstall autocompletions, follow the install_autocompletions.sh generated prompts, or simply run bash autocomplete/uninstall.sh.
Please note: using CLI with autocompletions enabled is strongly recommended.
Once installed, you should be able to start by running ais <TAB-TAB>, selecting one of the available (completion) options, and repeating until the command is ready to be entered.
TL;DR: see section CLI reference below to quickly locate useful commands. There’s also a (structured as a reference) list of CLI resources with numerous examples and usage guides that we constantly keep updating.
TIP: when starting with AIS, ais search command may be especially handy. It will list all possible variations of a command you are maybe looking for - by exact match, synonym, or regex.
See also:
The rest of the README assumes that user’s
PATHenvironment variable contains$GOPATH/bindirectory. Runexport PATH=$PATH:$GOPATH/binif this is not the case. You can find more about $GOPATH environment here.
CLI Reference
The recommended and quickest way to get started with CLI is to type ais and press <TAB-TAB>:
$ ais <TAB-TAB>
advanced         cluster          etl              ls               remote-cluster   space-cleanup
alias            config           evict            ml               rmb              start
archive          cp               get              object           rmo              stop
auth             create           help             performance      scrub            storage
blob-download    download         job              prefetch         search           tls
bucket           dsort            log              put              show             wait
These are the current set of top-level commands. Each command has its own extended help (the --help option) and, usually, multiple sub-commands
(which, in turn, have their respective inline helps and subcommands).
The list of top-level commands provides an overview of the supported functionality and functional grouping. The following is a brief (non-exhaustive and possibly slightly outdated) summary:
| Command | Use Case | 
|---|---|
| ais help | All top-level commands and brief descriptions; version and build; general usage guidelines. | 
| ais advanced | Special commands for developers and advanced usage. | 
| ais alias | User-defined command aliases. | 
| ais archive | Read, write, and list archives (i.e., objects formatted as TAR, TGZ, ZIP, etc.) | 
| ais auth | Add/remove/show users, manage user roles, manage access to remote clusters. | 
| ais blob-download | Download a large object or multiple objects from remote storage. | 
| ais bucket | Create/destroy buckets, list bucket’s content, show existing buckets and their properties. | 
| ais cluster | Monitor and manage AIS cluster: add/remove nodes, change primary gateway, etc. | 
| ais config | Set local/global AIS cluster configurations. | 
| ais etl | Execute custom transformations on objects. | 
| ais job | Query and manage jobs (aka eXtended actions or xactions). | 
| ais ml | Commands that target ML‑centric workflows, including bulk extraction of training samples. | 
| ais object | PUT and GET (write and read), APPEND, archive, concat, list (buckets, objects), move, evict, promote, ... | 
| ais search | Search aiscommands. | 
| ais show | Monitor anything and everything: performance (all aspects), buckets, jobs, remote clusters and more. | 
| ais log | Download ais nodes’ logs or view the logs in real time. | 
| ais storage | Show capacity usage on a per bucket basis (num objects and sizes), attach/detach mountpaths (disks). | 
| ais performance | Show performance counters, throughput, latency, disks, used/available capacities. | 
| ais tls | Load or reload (an updated) TLS certificate; display information about currently deployed certificates. | 
Other CLI documentation:
- ais help
- Reference guide
- Monitoring
- Cluster and node management
- Mountpath (disk) management
- Attach, detach, and monitor remote clusters
- Start, stop, and monitor downloads
- Distributed shuffle
- User account and access management
- Jobs
Note: In CLI docs, the terms “xaction” and “job” are used interchangeably.
CLI Config
Notice:
- CLI configuration directory: $HOME/.config/ais/cli
- CLI configuration filename: cli.json
- Reset: ais config cli reset
- One‑liner view: ais config cli --json | jq .
For the most updated system filenames and configuration directories, please see
fname/fname.gosource.
When used the very first time, or if the $HOME/.config/ais/cli/cli.json does not exist, the latter will be created with default parameters:
$ ais config cli --json
{
    "cluster": {
        "url": "http://127.0.0.1:8080",
        "default_ais_host": "http://127.0.0.1:8080",
        "default_docker_host": "http://172.50.0.2:8080",
        "client_crt": "",
        "client_crt_key": "",
        "client_ca_tls": "",
        "skip_verify_crt": false
    },
    "timeout": {
        "tcp_timeout": "60s",
        "http_timeout": "0s"
    },
    "auth": {
        "url": "http://127.0.0.1:52001"
    },
    "aliases": {
        "dsort": "job start dsort",
        "prefetch": "object prefetch",
        "rmo": "object rm",
        "get": "object get",
        "ls": "bucket ls",
        "wait": "job wait",
        "create": "bucket create",
        "download": "job start download",
        "start": "job start",
        "stop": "job stop",
        "blob-download": "job start blob-download",
        "cp": "bucket cp",
        "evict": "bucket evict",
        "put": "object put",
        "rmb": "bucket rm"
    },
    "default_provider": "ais",
    "no_color": false,
    "verbose": false,
    "no_more": false
}
CLI config can be updated using ais config cli set command or even simply by changing the config file.
The next time you run it CLI will use the updated values.
To get back to system defaults, run ais config cli reset.
Environment variables
First and foremost, there’s AIS_ENDPOINT. If defined, it’ll take precedence over “cluster.url” (section CLI Config above).
Example:
$ export AIS_ENDPOINT=https://10.07.56.68:51080
In addition, environment can be used to override client-side TLS (aka, HTTPS) configuration - the knobs “client_crt”, etc. also listed in the table below:
| Var name | Overrides cli.jsonfield | The corresponding CLI Config | 
|---|---|---|
| AIS_ENDPOINT | cluster.url | |
| AIS_CRT | X.509 certificate | “cluster.client_crt” | 
| AIS_CRT_KEY | X.509 certificate’s private key | “cluster.client_crt_key” | 
| AIS_CLIENT_CA | Certificate authority that authorized (signed) the certificate | “cluster.client_ca_tls” | 
| AIS_SKIP_VERIFY_CRT | true: skip X.509 cert verification (usually enabled to circumvent limitations of self-signed certs) | “cluster.skip_verify_crt” | 
Further references
- Generating self-signed certificates
- Deploying: 4 targets, 1 gateway, 6 mountpaths, AWS backend
- Accessing HTTPS-based cluster
- Testing with self-signed certificates
- [Observability: TLS related alerts]((/docs/https.md#observability-tls-related-alerts)
- Updating and reloading X.509 certificates
- Switching cluster between HTTP and HTTPS
First steps
To get the list of supported commands, run:
$ ais help
Alternatively, you could start making use of auto-completions by typing
aisand pressing TAB key two times in a row.
To check if the CLI can correctly contact the cluster and to get cluster status, run following command:
$ ais show cluster
Global options
Besides a set of options specific for each command, AIS CLI provides global options:
- --no-color- by default AIS CLI displays messages with colors (e.g, errors are printed in red color). Colors are automatically disabled if CLI output is redirected or environment variable- TERM=dumbis set. To disable colors in other cases, pass- --no-colorto the application.
Please note that the place of a global options in the command line is fixed. Global options must follow the application name directly. At the same time, the location of a command-specific option is arbitrary: you can put them anywhere. Examples:
$ # Correct usage of global and command-specific options.
$ ais --no-color ls ais://bck --props all
$ ais --no-color ls --props all ais://bck
$
$ # Incorrect usage of a global option.
$ ais ls ais://bck --props all --no-color
Backend Provider
The syntax provider://BUCKET_NAME (referred to as BUCKET in help messages) works across all commands.
For more details, please refer to each specific command’s documentation.
provider:// can be omitted if the default_provider config value is set (in such case the config value will be used implicitly).
Supported backend providers currently include:
- ais://- AIStore provider
- aws://or- s3://- Amazon Web Services
- azure://or- az://- Azure Blob Storage
- gcp://or- gs://- Google Cloud Storage
- ht://- HTTP(S) datasets
See also:
Backend Providers Buckets: definition, operations, properties
Verbose errors
CLI uses AIS API to execute operations on a cluster.
Of course, a remote API call - any API call, for that matter - may return errors. For developers, it may be sometimes useful to see a complete and unredacted error information.
Here’s an example where we are trying to rename a non-existing bucket:
$ ais bucket mv ais://ddd ais://mmm
Error: bucket "ais://ddd" does not exist
But here’s how it’ll look once we put CLI in verbose mode:
$ ais config cli set verbose true
"verbose" set to: "true" (was: "false")
$ ais bucket mv ais://ddd ais://mmm
Error: {"tcode":"ErrBckNotFound","message":"bucket \"ais://ddd\" does not exist","method":"HEAD","url_path":"/v1/buckets/ddd","remote_addr":"127.0.0.1:57026","caller":"","node":"p[JFkp8080]","status":404}: HEAD /v1/buckets/ddd (stack: [utils.go:445 <- bucket.go:104 <- bucket_hdlr.go:343])
CLI Help Paging
To view help content page-by-page, CLI uses the more command. Disable this by setting no_more to true in your configuration.
$ ais config cli set no_more=true
"no_more" set to: "true" (was: "false")