| 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 |  | 
| Anthony Young | 94c889a | 2011-10-11 18:07:48 +0000 | [diff] [blame] | 56 | # Get a token for clients that don't support service catalog | 
|  | 57 | # ========================================================== | 
|  | 58 | SERVICE_TOKEN=`curl -s -d  "{\"auth\":{\"passwordCredentials\": {\"username\": \"$NOVA_PROJECT_ID\", \"password\": \"$NOVA_API_KEY\"}}}" -H "Content-type: application/json" http://$HOST:5000/v2.0/tokens | python -c "import sys; import json; tok = json.loads(sys.stdin.read()); print tok['access']['token']['id'];"` | 
|  | 59 |  | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 60 | # Launching a server | 
|  | 61 | # ================== | 
| Jesse Andrews | b19424f | 2011-09-14 22:03:04 -0700 | [diff] [blame] | 62 |  | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 63 | # List servers for tenant: | 
| Jesse Andrews | b019151 | 2011-09-14 19:37:10 -0700 | [diff] [blame] | 64 | nova list | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 65 |  | 
|  | 66 | # List of flavors: | 
|  | 67 | nova flavor-list | 
|  | 68 |  | 
|  | 69 | # Images | 
|  | 70 | # ------ | 
|  | 71 |  | 
|  | 72 | # Nova has a **deprecated** way of listing images. | 
|  | 73 | nova image-list | 
|  | 74 |  | 
|  | 75 | # But we recommend using glance directly | 
| Anthony Young | 94c889a | 2011-10-11 18:07:48 +0000 | [diff] [blame] | 76 | glance -A $SERVICE_TOKEN index | 
| Jesse Andrews | 593828d | 2011-09-14 22:44:50 -0700 | [diff] [blame] | 77 |  | 
|  | 78 | # show details of the active servers:: | 
|  | 79 | # | 
|  | 80 | #     nova show 1234 | 
|  | 81 | # | 
|  | 82 | nova list | grep ACTIVE | cut -d \| -f2 | xargs -n1 nova show |