| Nikhil Manchanda | 0cccad4 | 2012-12-03 18:15:09 -0700 | [diff] [blame] | 1 | # lib/trove | 
|  | 2 | # Functions to control the configuration and operation of the **Trove** service | 
|  | 3 |  | 
|  | 4 | # Dependencies: | 
|  | 5 | # ``functions`` file | 
|  | 6 | # ``DEST``, ``STACK_USER`` must be defined | 
|  | 7 | # ``SERVICE_{HOST|PROTOCOL|TOKEN}`` must be defined | 
|  | 8 |  | 
|  | 9 | # ``stack.sh`` calls the entry points in this order: | 
|  | 10 | # | 
|  | 11 | # install_trove | 
|  | 12 | # configure_trove | 
|  | 13 | # init_trove | 
|  | 14 | # start_trove | 
|  | 15 | # stop_trove | 
|  | 16 | # cleanup_trove | 
|  | 17 |  | 
|  | 18 | # Save trace setting | 
|  | 19 | XTRACE=$(set +o | grep xtrace) | 
|  | 20 | set +o xtrace | 
|  | 21 |  | 
|  | 22 | # Defaults | 
|  | 23 | # -------- | 
|  | 24 |  | 
|  | 25 | NETWORK_GATEWAY=${NETWORK_GATEWAY:-10.0.0.1} | 
|  | 26 |  | 
|  | 27 | # Set up default configuration | 
|  | 28 | TROVE_DIR=$DEST/trove | 
|  | 29 | TROVECLIENT_DIR=$DEST/python-troveclient | 
|  | 30 | TROVE_CONF_DIR=/etc/trove | 
|  | 31 | TROVE_LOCAL_CONF_DIR=$TROVE_DIR/etc/trove | 
|  | 32 | TROVE_AUTH_ENDPOINT=$KEYSTONE_AUTH_PROTOCOL://$KEYSTONE_AUTH_HOST:$KEYSTONE_AUTH_PORT//v$IDENTITY_API_VERSION | 
|  | 33 | TROVE_AUTH_CACHE_DIR=${TROVE_AUTH_CACHE_DIR:-/var/cache/trove} | 
|  | 34 | TROVE_BIN_DIR=/usr/local/bin | 
|  | 35 |  | 
|  | 36 | # create_trove_accounts() - Set up common required trove accounts | 
|  | 37 |  | 
|  | 38 | # Tenant               User       Roles | 
|  | 39 | # ------------------------------------------------------------------ | 
|  | 40 | # service              trove     admin        # if enabled | 
|  | 41 |  | 
|  | 42 | create_trove_accounts() { | 
|  | 43 | # Trove | 
|  | 44 | SERVICE_TENANT=$(keystone tenant-list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }") | 
|  | 45 | SERVICE_ROLE=$(keystone role-list | awk "/ admin / { print \$2 }") | 
|  | 46 |  | 
|  | 47 | if [[ "$ENABLED_SERVICES" =~ "trove" ]]; then | 
|  | 48 | TROVE_USER=$(keystone user-create --name=trove \ | 
|  | 49 | --pass="$SERVICE_PASSWORD" \ | 
|  | 50 | --tenant_id $SERVICE_TENANT \ | 
|  | 51 | --email=trove@example.com \ | 
|  | 52 | | grep " id " | get_field 2) | 
|  | 53 | keystone user-role-add --tenant-id $SERVICE_TENANT \ | 
|  | 54 | --user-id $TROVE_USER \ | 
|  | 55 | --role-id $SERVICE_ROLE | 
|  | 56 | if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then | 
|  | 57 | TROVE_SERVICE=$(keystone service-create \ | 
|  | 58 | --name=trove \ | 
|  | 59 | --type=database \ | 
|  | 60 | --description="Trove Service" \ | 
|  | 61 | | grep " id " | get_field 2) | 
|  | 62 | keystone endpoint-create \ | 
|  | 63 | --region RegionOne \ | 
|  | 64 | --service_id $TROVE_SERVICE \ | 
|  | 65 | --publicurl "http://$SERVICE_HOST:8779/v1.0/\$(tenant_id)s" \ | 
|  | 66 | --adminurl "http://$SERVICE_HOST:8779/v1.0/\$(tenant_id)s" \ | 
|  | 67 | --internalurl "http://$SERVICE_HOST:8779/v1.0/\$(tenant_id)s" | 
|  | 68 | fi | 
|  | 69 | fi | 
|  | 70 | } | 
|  | 71 |  | 
|  | 72 | # stack.sh entry points | 
|  | 73 | # --------------------- | 
|  | 74 |  | 
|  | 75 | # cleanup_trove() - Remove residual data files, anything left over from previous | 
|  | 76 | # runs that a clean run would need to clean up | 
|  | 77 | function cleanup_trove() { | 
|  | 78 | #Clean up dirs | 
|  | 79 | rm -fr $TROVE_AUTH_CACHE_DIR/* | 
|  | 80 | rm -fr $TROVE_CONF_DIR/* | 
|  | 81 | } | 
|  | 82 |  | 
|  | 83 | # configure_troveclient() - Set config files, create data dirs, etc | 
|  | 84 | function configure_troveclient() { | 
|  | 85 | setup_develop $TROVECLIENT_DIR | 
|  | 86 | } | 
|  | 87 |  | 
|  | 88 | # configure_trove() - Set config files, create data dirs, etc | 
|  | 89 | function configure_trove() { | 
|  | 90 | setup_develop $TROVE_DIR | 
|  | 91 |  | 
|  | 92 | # Create the trove conf dir and cache dirs if they don't exist | 
|  | 93 | sudo mkdir -p ${TROVE_CONF_DIR} | 
|  | 94 | sudo mkdir -p ${TROVE_AUTH_CACHE_DIR} | 
|  | 95 | sudo chown -R $STACK_USER: ${TROVE_CONF_DIR} | 
|  | 96 | sudo chown -R $STACK_USER: ${TROVE_AUTH_CACHE_DIR} | 
|  | 97 |  | 
|  | 98 | # Copy api-paste file over to the trove conf dir and configure it | 
|  | 99 | cp $TROVE_LOCAL_CONF_DIR/api-paste.ini $TROVE_CONF_DIR/api-paste.ini | 
|  | 100 | TROVE_API_PASTE_INI=$TROVE_CONF_DIR/api-paste.ini | 
|  | 101 | iniset $TROVE_API_PASTE_INI filter:tokenauth auth_host $KEYSTONE_AUTH_HOST | 
|  | 102 | iniset $TROVE_API_PASTE_INI filter:tokenauth auth_port $KEYSTONE_AUTH_PORT | 
|  | 103 | iniset $TROVE_API_PASTE_INI filter:tokenauth auth_protocol $KEYSTONE_AUTH_PROTOCOL | 
|  | 104 | iniset $TROVE_API_PASTE_INI filter:tokenauth admin_tenant_name $SERVICE_TENANT_NAME | 
|  | 105 | iniset $TROVE_API_PASTE_INI filter:tokenauth admin_user trove | 
|  | 106 | iniset $TROVE_API_PASTE_INI filter:tokenauth admin_password $SERVICE_PASSWORD | 
|  | 107 | iniset $TROVE_API_PASTE_INI filter:tokenauth signing_dir $TROVE_AUTH_CACHE_DIR | 
|  | 108 |  | 
|  | 109 | # (Re)create trove conf files | 
|  | 110 | rm -f $TROVE_CONF_DIR/trove.conf | 
|  | 111 | rm -f $TROVE_CONF_DIR/trove-taskmanager.conf | 
|  | 112 | iniset $TROVE_CONF_DIR/trove.conf DEFAULT rabbit_password $RABBIT_PASSWORD | 
|  | 113 | iniset $TROVE_CONF_DIR/trove.conf DEFAULT sql_connection `database_connection_url trove` | 
|  | 114 | iniset $TROVE_CONF_DIR/trove.conf DEFAULT add_addresses True | 
|  | 115 |  | 
|  | 116 | iniset $TROVE_LOCAL_CONF_DIR/trove-guestagent.conf.sample DEFAULT rabbit_password $RABBIT_PASSWORD | 
|  | 117 | iniset $TROVE_LOCAL_CONF_DIR/trove-guestagent.conf.sample DEFAULT sql_connection `database_connection_url trove` | 
|  | 118 | sed -i "s/localhost/$NETWORK_GATEWAY/g" $TROVE_LOCAL_CONF_DIR/trove-guestagent.conf.sample | 
|  | 119 |  | 
|  | 120 | # (Re)create trove taskmanager conf file if needed | 
|  | 121 | if is_service_enabled tr-tmgr; then | 
|  | 122 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT rabbit_password $RABBIT_PASSWORD | 
|  | 123 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT sql_connection `database_connection_url trove` | 
|  | 124 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT taskmanager_manager trove.taskmanager.manager.Manager | 
|  | 125 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT nova_proxy_admin_user radmin | 
|  | 126 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT nova_proxy_admin_tenant_name trove | 
|  | 127 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT nova_proxy_admin_pass $RADMIN_USER_PASS | 
|  | 128 | iniset $TROVE_CONF_DIR/trove-taskmanager.conf DEFAULT trove_auth_url $TROVE_AUTH_ENDPOINT | 
|  | 129 | fi | 
|  | 130 | } | 
|  | 131 |  | 
|  | 132 | # install_troveclient() - Collect source and prepare | 
|  | 133 | function install_troveclient() { | 
|  | 134 | git_clone $TROVECLIENT_REPO $TROVECLIENT_DIR $TROVECLIENT_BRANCH | 
|  | 135 | } | 
|  | 136 |  | 
|  | 137 | # install_trove() - Collect source and prepare | 
|  | 138 | function install_trove() { | 
|  | 139 | git_clone $TROVE_REPO $TROVE_DIR $TROVE_BRANCH | 
|  | 140 | } | 
|  | 141 |  | 
|  | 142 | # init_trove() - Initializes Trove Database as a Service | 
|  | 143 | function init_trove() { | 
|  | 144 | #(Re)Create trove db | 
|  | 145 | recreate_database trove utf8 | 
|  | 146 |  | 
|  | 147 | #Initialize the trove database | 
|  | 148 | $TROVE_DIR/bin/trove-manage db_sync | 
|  | 149 | } | 
|  | 150 |  | 
|  | 151 | # start_trove() - Start running processes, including screen | 
|  | 152 | function start_trove() { | 
|  | 153 | screen_it tr-api "cd $TROVE_DIR; bin/trove-api --config-file=$TROVE_CONF_DIR/trove.conf --debug 2>&1" | 
|  | 154 | screen_it tr-tmgr "cd $TROVE_DIR; bin/trove-taskmanager --config-file=$TROVE_CONF_DIR/trove-taskmanager.conf --debug 2>&1" | 
|  | 155 | } | 
|  | 156 |  | 
|  | 157 | # stop_trove() - Stop running processes | 
|  | 158 | function stop_trove() { | 
|  | 159 | # Kill the trove screen windows | 
|  | 160 | for serv in tr-api tr-tmgr; do | 
|  | 161 | screen -S $SCREEN_NAME -p $serv -X kill | 
|  | 162 | done | 
|  | 163 | } | 
|  | 164 |  | 
|  | 165 | # Restore xtrace | 
|  | 166 | $XTRACE | 
|  | 167 |  | 
|  | 168 | # Local variables: | 
|  | 169 | # mode: shell-script | 
|  | 170 | # End: |