| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 1 | #!/usr/bin/env bash | 
 | 2 |  | 
 | 3 | # **exercise.sh** - using the cloud can be fun | 
 | 4 |  | 
 | 5 | # we will use the ``nova`` cli tool provided by the ``python-novaclient`` | 
 | 6 | # package | 
| Jesse Andrews | b19424f | 2011-09-14 22:03:04 -0700 | [diff] [blame] | 7 | # | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 8 |  | 
| Jesse Andrews | b19424f | 2011-09-14 22:03:04 -0700 | [diff] [blame] | 9 |  | 
 | 10 | # This script exits on an error so that errors don't compound and you see  | 
 | 11 | # only the first error that occured. | 
 | 12 | set -o errexit | 
 | 13 |  | 
 | 14 | # Print the commands being run so that we can see the command that triggers  | 
 | 15 | # an error.  It is also useful for following allowing as the install occurs. | 
 | 16 | set -o xtrace | 
 | 17 |  | 
 | 18 |  | 
 | 19 | # Settings | 
 | 20 | # ======== | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 21 |  | 
 | 22 | HOST=${HOST:-localhost} | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 23 |  | 
| Jesse Andrews | b19424f | 2011-09-14 22:03:04 -0700 | [diff] [blame] | 24 | # Nova original used project_id as the *account* that owned resources (servers, | 
 | 25 | # ip address, ...)   With the addition of Keystone we have standardized on the | 
 | 26 | # term **tenant** as the entity that owns the resources.  **novaclient** still | 
| Anthony Young | 0edde7d | 2011-10-06 07:10:24 -0700 | [diff] [blame] | 27 | # uses the old deprecated terms project_id.  Note that this field should now be | 
 | 28 | # set to tenant_name, not tenant_id. | 
 | 29 | export NOVA_PROJECT_ID=${TENANT:-demo} | 
| Jesse Andrews | b19424f | 2011-09-14 22:03:04 -0700 | [diff] [blame] | 30 |  | 
 | 31 | # In addition to the owning entity (tenant), nova stores the entity performing | 
 | 32 | # the action as the **user**. | 
 | 33 | export NOVA_USERNAME=${USERNAME:-demo} | 
 | 34 |  | 
 | 35 | # With Keystone you pass the keystone password instead of an api key. | 
 | 36 | export NOVA_API_KEY=${PASSWORD:-secrete} | 
 | 37 |  | 
 | 38 | # With the addition of Keystone, to use an openstack cloud you should  | 
 | 39 | # authenticate against keystone, which returns a **Token** and **Service  | 
 | 40 | # Catalog**.  The catalog contains the endpoint for all services the user/tenant  | 
 | 41 | # has access to - including nova, glance, keystone, swift, ...  We currently  | 
 | 42 | # recommend using the 2.0 *auth api*.   | 
 | 43 | # | 
 | 44 | # *NOTE*: Using the 2.0 *auth api* does mean that compute api is 2.0.  We will | 
 | 45 | # use the 1.1 *compute api* | 
 | 46 | export NOVA_URL=${NOVA_URL:-http://$HOST:5000/v2.0/} | 
 | 47 |  | 
 | 48 | # Currently novaclient needs you to specify the *compute api* version.  This | 
 | 49 | # needs to match the config of your catalog returned by Keystone. | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 50 | export NOVA_VERSION=1.1 | 
 | 51 |  | 
| Anthony Young | 4387690 | 2011-09-27 00:29:28 -0700 | [diff] [blame] | 52 | # FIXME - why does this need to be specified? | 
 | 53 | export NOVA_REGION_NAME=RegionOne | 
 | 54 |  | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 55 |  | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 56 | # Launching a server | 
 | 57 | # ================== | 
| Jesse Andrews | b19424f | 2011-09-14 22:03:04 -0700 | [diff] [blame] | 58 |  | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 59 | # List servers for tenant: | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 60 | nova list | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 61 |  | 
 | 62 | # List of flavors: | 
 | 63 | nova flavor-list | 
 | 64 |  | 
 | 65 | # Images | 
 | 66 | # ------ | 
 | 67 |  | 
 | 68 | # Nova has a **deprecated** way of listing images. | 
 | 69 | nova image-list | 
 | 70 |  | 
 | 71 | # But we recommend using glance directly | 
 | 72 | glance index | 
 | 73 |  | 
 | 74 | # show details of the active servers:: | 
 | 75 | # | 
 | 76 | #     nova show 1234 | 
 | 77 | # | 
 | 78 | nova list | grep ACTIVE | cut -d \| -f2 | xargs -n1 nova show |