ciao-cli

command
v0.0.0-...-476269e Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 31, 2017 License: Apache-2.0 Imports: 37 Imported by: 0

README

ciao-cli

Command-line interface for the Cloud Integrated Advanced Orchestrator (CIAO).

ciao-cli sends HTTPS requests to the Ciao controller compute API endpoints.

Usage

ciao-cli: Command-line interface for the Cloud Integrated Advanced Orchestrator (CIAO)                                    [8/381]

Usage:

        ciao-cli [options] command sub-command [flags]

The options are:

  -alsologtostderr
        log to standard error as well as files
  -ca-file string
        CA Certificate
  -computeport int
        Openstack Compute API port (default 8774)
  -controller string
        Controller URL
  -identity string
        Keystone URL
  -log_backtrace_at value
        when logging hits line file:N, emit a stack trace (default :0)
  -log_dir string
        If non-empty, write log files in this directory
  -logtostderr
        log to standard error instead of files
  -password string
        Openstack Service Password
  -stderrthreshold value
        logs at or above this threshold go to stderr
  -tenant-id string
        Tenant UUID
  -tenant-name string
        Tenant name
  -username string
        Openstack Service Username
  -v value
        log level for V logs
  -vmodule value
        comma-separated list of pattern=N settings for file-filtered logging


The commands are:

        event
	external-ip
	image
        instance
        node
	pool
        tenant
        trace
	volume
        workload

Use "ciao-cli command -help" for more information about that command.

Ciao environment variables

ciao-cli first looks for Ciao specific environment variables to retrieve credentials and networking information:

  • CIAO_CONTROLLER exports the Ciao controller URL
  • CIAO_IDENTITY exports the Ciao keystone instance URL
  • CIAO_COMPUTEPORT exports the Ciao compute alternative port
  • CIAO_USERNAME exports the Ciao username
  • CIAO_PASSWORD export the Ciao password for CIAO_USERNAME
  • CIAO_TENANT_NAME export the Ciao tenant name for CIAO_USERNAME
  • CIAO_CA_CERT_FILE (optional) use the supplied certificate as the CA

All those environment variables can be set through an rc file. For example:

$ cat ciao-cli-example.sh

export CIAO_CONTROLLER=ciao-ctl.intel.com
export CIAO_IDENTITY=https://ciao-identity.intel.com:35357
export CIAO_USERNAME=user
export CIAO_PASSWORD=ciaouser
export CIAO_TENANT_NAME=admin

Exporting those variables is not compulsory and they can be defined or overridden from the ciao-cli command line.

Keystone certificates

ciao-cli interacts with the CIAO keystone instance over HTTPS. As such you will need to have the keystone CA certificate available in order to make requests. You can either install the CA certificate system-wide:

  • On Fedora:
sudo cp keystone_ca_cert.pem /etc/pki/ca-trust/source/anchors/
sudo update-ca-trust
  • On Ubuntu
sudo cp keystone_ca_cert.pem /usr/local/share/ca-certificates/keystone.crt
sudo update-ca-certificates

Or, alternatively the CA certificate may be specified with the -ca-file command line or with the CIAO_CA_CERT_FILE environment variable.

Priviledged versus non priviledged CIAO users

Administrators of a CIAO cluster are privileged users that are part of the admin or service projects. They are allowed to run each and every ciao-cli commands. Some ciao-cli commands are privileged and can only be run by administrators.

Non privileged commands can be run by all users. Administrators will have to specify a tenant/project UUID through the -tenant option in order to specify against which CIAO tenant/project they're running the command:

$GOBIN/ciao-cli -password ciao -username admin instance list -tenant 68a76514-5c8e-40a8-8c9e-0570a11d035b

Non privileged users belonging to several tenants/projects will also have to specify a tenant/project UUID or name through either the -tenant-id or -tenant-name options in order to specify against which CIAO tenant/project they're running the command:

$GOBIN/ciao-cli -username user -password ciaouser -tenant-name project1 instance list

Non privileged users belonging to only one single tenant/project do not need to pass the tenant/project UUID or name when running non privileged commands:

$GOBIN/ciao-cli -username user -password ciaouser instance list

Examples

Let's assume we're running a Ciao cluster with the following settings:

  • The Ciao controller is running at ciao-ctl.intel.com
  • The Keystone server is running at https://ciao-identity.intel.com:35357
  • The admin user is part of the admin project
  • The admin password is ciao
  • The user user is part of only one project: project1
  • The password for user is ciaouser
  • project1 UUID is 68a76514-5c8e-40a8-8c9e-0570a11d035b

This can be defined through the following Ciao rc file:

$ cat ciao-cli-example.sh

export CIAO_CONTROLLER=ciao-ctl.intel.com
export CIAO_IDENTITY=https://ciao-identity.intel.com:35357
export CIAO_USERNAME=user
export CIAO_PASSWORD=ciaouser
export CIAO_TENANT_NAME=project1
Cluster status (Privileged)
$GOBIN/ciao-cli -username admin -password ciao node status
List all compute nodes (Privileged)
$GOBIN/ciao-cli -username admin -password ciao node list -compute
List all CNCIs (Privileged)
$GOBIN/ciao-cli -username admin -password ciao node list -cnci
List all tenants/projects (Privileged)
$GOBIN/ciao-cli -username admin -password ciao tenant list -all
List quotas
$GOBIN/ciao-cli tenant list -quotas
List consumed resources
$GOBIN/ciao-cli tenant list -resources
List all instances
$GOBIN/ciao-cli instance list
List at most the first 10 instances
$GOBIN/ciao-cli instance list -limit 10
List at most the 20 instances starting from instance number 10
$GOBIN/ciao-cli instance list -limit 20 -offset 10
List all workloads
$GOBIN/ciao-cli workload list
Launch a new instance
$GOBIN/ciao-cli instance add -workload 69e84267-ed01-4738-b15f-b47de06b62e7
Launch 1000 new instances
$GOBIN/ciao-cli instance add -workload 69e84267-ed01-4738-b15f-b47de06b62e7 -instances 1000
Launch 1000 instances and trace them
$GOBIN/ciao-cli instance add -workload 69e84267-ed01-4738-b15f-b47de06b62e7 -label start_trace_20160415 -instances 1000
Stop a running instance
$GOBIN/ciao-cli instance stop -instance 4c46ace5-cf92-4ce5-a0ac-68f6d524f8aa
Restart a stopped instance
$GOBIN/ciao-cli instance restart -instance 4c46ace5-cf92-4ce5-a0ac-68f6d524f8aa
Delete an instance
$GOBIN/ciao-cli instance delete -instance 4c46ace5-cf92-4ce5-a0ac-68f6d524f8aa
Delete all instances for a given tenant
$GOBIN/ciao-cli instance delete -all
List all available trace labels (Privileged)
$GOBIN/ciao-cli -username admin -password ciao trace list
Dump and display trace data from a given trace label (Privileged)
$GOBIN/ciao-cli -username admin -password ciao trace show -label start_trace_20160415
List all cluster events (Privileged)
$GOBIN/ciao-cli -username admin -password ciao event list -all
List all cluster events for a given tenant
$GOBIN/ciao-cli event list

Scripting with ciao-cli

Most of the ciao-cli commands contain a list or show subcommand, e.g.,

ciao-cli instance list

By default, these commands format their output in a style that is pleasing to the human eye. For example,

# ciao-cli instance show --instance cef5b810-5ffb-4dee-ab95-29748869afb6

    UUID: cef5b810-5ffb-4dee-ab95-29748869afb6
    Status: active
    Private IP: 172.16.0.3
    MAC Address: 02:00:ac:10:00:03
    CN UUID: fe4fa7da-0c46-46cf-9205-28c9d675aa5a
    Image UUID: 73a86d7e-93c0-480e-9c41-ab42f69b7799
    Tenant UUID: f452bbc7-5076-44d5-922c-3b9d2ce1503f
    SSH IP: 198.51.100.75
    SSH Port: 33003

However, this is not always what we want, particularly if we are writing a script to automate a set of ciao commands. For example, say we wanted to programmatically retrieve the ssh connection details for the above instance. Using the command above we'd need to do some scripting to ignore the first 7 lines and extract the IP and port number from lines 8 and 9. Nasty.

Luckily all the ciao-cli show and list commands accept a -f option which is specified along with a Go template. These templates are little programs that can be used to extract the specific data we are interested in. For example, to extract the SSH IP and port numbers we would issue the following command.

# ciao-cli instance show --instance cef5b810-5ffb-4dee-ab95-29748869afb6 -f '{{.SSHIP}}:{{.SSHPort}}'

198.51.100.75:33003

No parsing required.

Check the help for each individual show and list command to discover which fields, e.g., SSHIP, are supported. For example,

# ciao-cli instance show --help

usage: ciao-cli [options] instance show [flags]

Print detailed information about an instance

The show flags are:

  -f string
    	Template used to format output
  -instance string
    	Instance UUID

The template passed to the -f option operates on a

struct {
	HostID   string                               // ID of the host node
	ID       string                               // Instance UUID
	TenantID string                               // Tenant UUID
	Flavor   struct {
		ID string                             // Workload UUID
	}
	Image struct {
		ID string                             // Backing image UUID
	}
	Status    string                              // Instance status
	Addresses struct {
		Private []struct {
			Addr               string     // Instance IP address
			OSEXTIPSMACMacAddr string     // Instance MAC address
		}
	}
	SSHIP   string                                // Instance SSH IP address
	SSHPort int                                   // Instance SSH Port
}
Template Cheat Sheet

Let's look at a few more examples of how we can use templates to extract information from the ciao-cli command. Looking at the help of the ciao-cli instance show command shown above we can see that ciao-cli passes a structure to the template passed to the -f option. The members of this structure can be accessed inside template code by prefixing their name with '.'. For example the following command prints out the ID of an instance.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{.ID}}'
80efbb0a-23ae-4d47-8e74-39fb18497c85 $

Note the command prints out the instance without a newline which can be a bit confusing. We can fix this by including a newline character directly in the template.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{.ID}}
> '
80efbb0a-23ae-4d47-8e74-39fb18497c85
#

or by using the println function

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{println .ID}}'
80efbb0a-23ae-4d47-8e74-39fb18497c85
#

Here's a more elaborate example in which we output the id, the status and ssh connection details of the instance.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{.ID}} ({{.Status}}) {{.SSHIP}}:{{.SSHPort}}{{println}}'
80efbb0a-23ae-4d47-8e74-39fb18497c85 (active) 198.51.100.96:33002
#

Now let's take a look at the Addresses field. This field is a structure that contains a slice of structures. We can gain access to this slice as follows .Addresses.Private. Let's output the slice to see what happens.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{println .Addresses.Private}}'
[{172.16.0.2 02:00:ac:10:00:02  0}]
#

We see what appears to be a slice of structures. We can use the template range and index commands to access the elements of this slice. For example to output the MAC addresses of each structure we would type:

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{range .Addresses.Private}}{{println .OSEXTIPSMACMacAddr}}{{end}}'
02:00:ac:10:00:02
#

Note that inside the {{range}}{{end}} tags the meaning of the . cursor changes. Rather than referring to the entire structure passed to template it refers to an individual element of the .Addresses.Private slice. If you want to access a field of the top level structure inside the range statement you need to use the $ operator. For example, the following command prints the HostID of the instance before it prints each MAC address.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{range .Addresses.Private}}{{$.HostID}} : {{println .OSEXTIPSMACMacAddr}}{{end}}'
c483c178-2109-4a54-bf00-98cbf4bfa58b : 02:00:ac:10:00:02
#

If we are only interested in the MAC address of a specific element of the slice we can access it directly.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{println (index .Addresses.Private 0).OSEXTIPSMACMacAddr}}'
02:00:ac:10:00:02
#

If you find the expression (index .Addresses.Private 0).OSEXTIPSMACMacAddr a little confusing you can split things up by introducing a new variable.

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{$addr := index .Addresses.Private 0}}{{println $addr.OSEXTIPSMACMacAddr}}'
02:00:ac:10:00:02
#

Here the $addr variable becomes the first element of the slice. $addr itself is a structure and so we can use the . operator to access its fields.

However, there's a problem with this approach. We don't know in advance how many entries are present in the .Addresses.Private slice. If we try to index an element that doesn't exist we'll get an error. For example,

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{$addr := index .Addresses.Private 1}}{{println $addr.OSEXTIPSMACMacAddr}}'
F1117 10:54:29.246108    8776 template.go:30] ciao-cli FATAL: template: instance-show:1:11: executing "instance-show" at <index .Addresses.Pri...>: error calling index: index out of range: 1
goroutine 1 [running]:

We can use the if statement to prevent us from accessing non-existing elements, e.g.,

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{if gt (len .Addresses.Private) 1}}{{$addr := index .Addresses.Private 1}}{{println $addr.OSEXTIPSMACMacAddr}}{{end}}'
#

The command prints nothing as our if statement evaluates to false. There's only one element in .Addresses.Private slice.

Note in the previous example we use the rather unwieldy .Addresses.Private twice. We can eliminate the repetition using the with statement, e.g.,

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{with .Addresses.Private}}{{if gt (len .) 1}}{{$addr := index . 1}}{{println $addr.OSEXTIPSMACMacAddr}}{{end}}{{end}}'
#

Inside the with statement the . cursor takes on a new meaning. It becomes assigned to the value of .Addresses.Private.

The example above is getting a little big to fit onto one line. We might find it easier to read if it were split onto multiple lines, e.g.,

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{with .Addresses.Private}}
>   {{if gt (len .) 1}}
>     {{$addr := index . 1}}{{println $addr.OSEXTIPSMACMacAddr}}
>   {{end}}
> {{end}}
> '




#

This is easier to read but unfortunately the newlines in the template that we added to improve readability get copied to the output. We can fix this by appending a '-' after the {{s and before the }}s, e.g.,

# ciao-cli instance show --instance 80efbb0a-23ae-4d47-8e74-39fb18497c85 --f '{{with .Addresses.Private}}
  {{- if gt (len .) 1}}
    {{- $addr := index . 1}}{{println $addr.OSEXTIPSMACMacAddr}}
  {{- end}}
{{- end -}}
#
'

The '-'s gobble up the white space that occurs before the {{- and after the -}}.

Here's one final example. Let's take a look at the help for the ciao-cli workload list command.

ciao-cli workload list --help
usage: ciao-cli [options] workload list

List all workloads

  -f string
    	Template used to format output

The template passed to the -f option operates on a

[]struct {
	OSFLVDISABLEDDisabled  bool    // Not used
	Disk                   string  // Backing images associated with workload
	OSFLVEXTDATAEphemeral  int     // Not currently used
	OsFlavorAccessIsPublic bool    // Indicates whether the workload is available to all tenants
	ID                     string  // ID of the workload
	Links                  []Link  // Not currently used
	Name                   string  // Name of the workload
	RAM                    int     // Amount of RAM allocated to instances of this workload
	Swap                   string  // Not currently used
	Vcpus                  int     // Number of Vcpus allocated to instances of this workload
}

The important thing to note here is that the template is passed a slice of structures. That means we need to use template function that can handle slices, e.g., len, index or range. So to determine the number of workloads available we would type.

# ciao-cli workload list -f '{{println (len .)'}}
5

To output the names of each workload we might do

# ciao-cli workload list -f '{{range .}}{{println .Name}}{{end}}'
Fedora 24 Cloud
Clear Cloud
Docker Debian latest
Docker Iperf
Boot Fedora24 from created volume based on image

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL