Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 1 | # lib/cinder |
Dean Troyer | 6d04fd7 | 2012-12-21 11:03:37 -0600 | [diff] [blame] | 2 | # Install and start **Cinder** volume service |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 3 | |
| 4 | # Dependencies: |
| 5 | # - functions |
Attila Fazekas | 91b8d13 | 2013-01-06 22:40:09 +0100 | [diff] [blame] | 6 | # - DEST, DATA_DIR, STACK_USER must be defined |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 7 | # SERVICE_{TENANT_NAME|PASSWORD} must be defined |
Dean Troyer | bc071bc | 2012-10-01 14:06:44 -0500 | [diff] [blame] | 8 | # ``KEYSTONE_TOKEN_FORMAT`` must be defined |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 9 | |
| 10 | # stack.sh |
| 11 | # --------- |
Attila Fazekas | b79574b | 2012-12-01 10:42:46 +0100 | [diff] [blame] | 12 | # install_cinder |
| 13 | # configure_cinder |
| 14 | # init_cinder |
| 15 | # start_cinder |
| 16 | # stop_cinder |
| 17 | # cleanup_cinder |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 18 | |
Dean Troyer | 7903b79 | 2012-09-13 17:16:12 -0500 | [diff] [blame] | 19 | # Save trace setting |
| 20 | XTRACE=$(set +o | grep xtrace) |
| 21 | set +o xtrace |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 22 | |
| 23 | |
| 24 | # Defaults |
| 25 | # -------- |
| 26 | |
Mate Lakat | b2fdafe | 2012-11-20 15:52:21 +0000 | [diff] [blame] | 27 | # set up default driver |
| 28 | CINDER_DRIVER=${CINDER_DRIVER:-default} |
| 29 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 30 | # set up default directories |
| 31 | CINDER_DIR=$DEST/cinder |
Dean Troyer | 50ac792 | 2012-09-13 14:02:01 -0500 | [diff] [blame] | 32 | CINDERCLIENT_DIR=$DEST/python-cinderclient |
| 33 | CINDER_STATE_PATH=${CINDER_STATE_PATH:=$DATA_DIR/cinder} |
Dean Troyer | 671c16e | 2012-12-13 16:22:38 -0600 | [diff] [blame] | 34 | CINDER_AUTH_CACHE_DIR=${CINDER_AUTH_CACHE_DIR:-/var/cache/cinder} |
| 35 | |
Dean Troyer | 50ac792 | 2012-09-13 14:02:01 -0500 | [diff] [blame] | 36 | CINDER_CONF_DIR=/etc/cinder |
| 37 | CINDER_CONF=$CINDER_CONF_DIR/cinder.conf |
Dean Troyer | 671c16e | 2012-12-13 16:22:38 -0600 | [diff] [blame] | 38 | CINDER_API_PASTE_INI=$CINDER_CONF_DIR/api-paste.ini |
Dean Troyer | 50ac792 | 2012-09-13 14:02:01 -0500 | [diff] [blame] | 39 | |
Dean Troyer | 560346b | 2012-12-13 17:05:24 -0600 | [diff] [blame] | 40 | # Public facing bits |
| 41 | CINDER_SERVICE_HOST=${CINDER_SERVICE_HOST:-$SERVICE_HOST} |
| 42 | CINDER_SERVICE_PORT=${CINDER_SERVICE_PORT:-8776} |
| 43 | CINDER_SERVICE_PORT_INT=${CINDER_SERVICE_PORT_INT:-18776} |
| 44 | CINDER_SERVICE_PROTOCOL=${CINDER_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL} |
| 45 | |
Dean Troyer | 50ac792 | 2012-09-13 14:02:01 -0500 | [diff] [blame] | 46 | # Support entry points installation of console scripts |
| 47 | if [[ -d $CINDER_DIR/bin ]]; then |
Monty Taylor | 9fbeedd | 2012-08-17 12:52:27 -0400 | [diff] [blame] | 48 | CINDER_BIN_DIR=$CINDER_DIR/bin |
| 49 | else |
Jakub Ruzicka | 4196d55 | 2013-01-30 15:35:54 +0100 | [diff] [blame] | 50 | CINDER_BIN_DIR=$(get_python_exec_prefix) |
Monty Taylor | 9fbeedd | 2012-08-17 12:52:27 -0400 | [diff] [blame] | 51 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 52 | |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 53 | # Support for multi lvm backend configuration (default is no support) |
| 54 | CINDER_MULTI_LVM_BACKEND=$(trueorfalse False $CINDER_MULTI_LVM_BACKEND) |
| 55 | |
Dean Troyer | b7490da | 2013-03-18 16:07:56 -0500 | [diff] [blame] | 56 | # Should cinder perform secure deletion of volumes? |
| 57 | # Defaults to true, can be set to False to avoid this bug when testing: |
| 58 | # https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1023755 |
| 59 | CINDER_SECURE_DELETE=`trueorfalse True $CINDER_SECURE_DELETE` |
| 60 | |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 61 | # Name of the lvm volume groups to use/create for iscsi volumes |
| 62 | # VOLUME_GROUP2 is used only if CINDER_MULTI_LVM_BACKEND = True |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 63 | VOLUME_GROUP=${VOLUME_GROUP:-stack-volumes} |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 64 | VOLUME_GROUP2=${VOLUME_GROUP2:-stack-volumes2} |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 65 | VOLUME_NAME_PREFIX=${VOLUME_NAME_PREFIX:-volume-} |
| 66 | |
Dean Troyer | 22853c1 | 2013-01-07 15:18:12 -0600 | [diff] [blame] | 67 | # _clean_volume_group removes all cinder volumes from the specified volume group |
| 68 | # _clean_volume_group $VOLUME_GROUP $VOLUME_NAME_PREFIX |
| 69 | function _clean_volume_group() { |
| 70 | local vg=$1 |
| 71 | local vg_prefix=$2 |
| 72 | # Clean out existing volumes |
| 73 | for lv in `sudo lvs --noheadings -o lv_name $vg`; do |
| 74 | # vg_prefix prefixes the LVs we want |
| 75 | if [[ "${lv#$vg_prefix}" != "$lv" ]]; then |
| 76 | sudo lvremove -f $vg/$lv |
| 77 | fi |
| 78 | done |
| 79 | } |
| 80 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 81 | # cleanup_cinder() - Remove residual data files, anything left over from previous |
| 82 | # runs that a clean run would need to clean up |
| 83 | function cleanup_cinder() { |
Sean Dague | 252f2f5 | 2012-12-20 16:41:57 -0500 | [diff] [blame] | 84 | # ensure the volume group is cleared up because fails might |
| 85 | # leave dead volumes in the group |
| 86 | TARGETS=$(sudo tgtadm --op show --mode target) |
| 87 | if [ $? -ne 0 ]; then |
| 88 | # If tgt driver isn't running this won't work obviously |
| 89 | # So check the response and restart if need be |
| 90 | echo "tgtd seems to be in a bad state, restarting..." |
| 91 | if is_ubuntu; then |
| 92 | restart_service tgt |
| 93 | else |
| 94 | restart_service tgtd |
| 95 | fi |
| 96 | TARGETS=$(sudo tgtadm --op show --mode target) |
| 97 | fi |
| 98 | |
| 99 | if [[ -n "$TARGETS" ]]; then |
| 100 | iqn_list=( $(grep --no-filename -r iqn $SCSI_PERSIST_DIR | sed 's/<target //' | sed 's/>//') ) |
| 101 | for i in "${iqn_list[@]}"; do |
| 102 | echo removing iSCSI target: $i |
| 103 | sudo tgt-admin --delete $i |
| 104 | done |
| 105 | fi |
| 106 | |
| 107 | if is_service_enabled cinder; then |
| 108 | sudo rm -rf $CINDER_STATE_PATH/volumes/* |
| 109 | fi |
| 110 | |
| 111 | if is_ubuntu; then |
| 112 | stop_service tgt |
| 113 | else |
| 114 | stop_service tgtd |
| 115 | fi |
| 116 | |
Dean Troyer | 22853c1 | 2013-01-07 15:18:12 -0600 | [diff] [blame] | 117 | # Campsite rule: leave behind a volume group at least as clean as we found it |
| 118 | _clean_volume_group $VOLUME_GROUP $VOLUME_NAME_PREFIX |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 119 | if [ "$CINDER_MULTI_LVM_BACKEND" = "True" ]; then |
| 120 | _clean_volume_group $VOLUME_GROUP2 $VOLUME_NAME_PREFIX |
| 121 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 122 | } |
| 123 | |
| 124 | # configure_cinder() - Set config files, create data dirs, etc |
| 125 | function configure_cinder() { |
| 126 | setup_develop $CINDER_DIR |
| 127 | setup_develop $CINDERCLIENT_DIR |
| 128 | |
| 129 | if [[ ! -d $CINDER_CONF_DIR ]]; then |
| 130 | sudo mkdir -p $CINDER_CONF_DIR |
| 131 | fi |
Attila Fazekas | 91b8d13 | 2013-01-06 22:40:09 +0100 | [diff] [blame] | 132 | sudo chown $STACK_USER $CINDER_CONF_DIR |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 133 | |
| 134 | cp -p $CINDER_DIR/etc/cinder/policy.json $CINDER_CONF_DIR |
| 135 | |
John Griffith | 4e823ff | 2012-07-20 13:18:17 -0600 | [diff] [blame] | 136 | # Set the paths of certain binaries |
Vincent Untz | 856a11e | 2012-11-21 16:04:12 +0100 | [diff] [blame] | 137 | CINDER_ROOTWRAP=$(get_rootwrap_location cinder) |
John Griffith | 4e823ff | 2012-07-20 13:18:17 -0600 | [diff] [blame] | 138 | |
| 139 | # If Cinder ships the new rootwrap filters files, deploy them |
| 140 | # (owned by root) and add a parameter to $CINDER_ROOTWRAP |
| 141 | ROOTWRAP_CINDER_SUDOER_CMD="$CINDER_ROOTWRAP" |
| 142 | if [[ -d $CINDER_DIR/etc/cinder/rootwrap.d ]]; then |
| 143 | # Wipe any existing rootwrap.d files first |
| 144 | if [[ -d $CINDER_CONF_DIR/rootwrap.d ]]; then |
| 145 | sudo rm -rf $CINDER_CONF_DIR/rootwrap.d |
| 146 | fi |
| 147 | # Deploy filters to /etc/cinder/rootwrap.d |
| 148 | sudo mkdir -m 755 $CINDER_CONF_DIR/rootwrap.d |
| 149 | sudo cp $CINDER_DIR/etc/cinder/rootwrap.d/*.filters $CINDER_CONF_DIR/rootwrap.d |
| 150 | sudo chown -R root:root $CINDER_CONF_DIR/rootwrap.d |
| 151 | sudo chmod 644 $CINDER_CONF_DIR/rootwrap.d/* |
| 152 | # Set up rootwrap.conf, pointing to /etc/cinder/rootwrap.d |
| 153 | sudo cp $CINDER_DIR/etc/cinder/rootwrap.conf $CINDER_CONF_DIR/ |
| 154 | sudo sed -e "s:^filters_path=.*$:filters_path=$CINDER_CONF_DIR/rootwrap.d:" -i $CINDER_CONF_DIR/rootwrap.conf |
| 155 | sudo chown root:root $CINDER_CONF_DIR/rootwrap.conf |
| 156 | sudo chmod 0644 $CINDER_CONF_DIR/rootwrap.conf |
| 157 | # Specify rootwrap.conf as first parameter to cinder-rootwrap |
| 158 | CINDER_ROOTWRAP="$CINDER_ROOTWRAP $CINDER_CONF_DIR/rootwrap.conf" |
| 159 | ROOTWRAP_CINDER_SUDOER_CMD="$CINDER_ROOTWRAP *" |
| 160 | fi |
| 161 | |
| 162 | TEMPFILE=`mktemp` |
| 163 | echo "$USER ALL=(root) NOPASSWD: $ROOTWRAP_CINDER_SUDOER_CMD" >$TEMPFILE |
| 164 | chmod 0440 $TEMPFILE |
| 165 | sudo chown root:root $TEMPFILE |
| 166 | sudo mv $TEMPFILE /etc/sudoers.d/cinder-rootwrap |
| 167 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 168 | cp $CINDER_DIR/etc/cinder/api-paste.ini $CINDER_API_PASTE_INI |
| 169 | iniset $CINDER_API_PASTE_INI filter:authtoken auth_host $KEYSTONE_AUTH_HOST |
| 170 | iniset $CINDER_API_PASTE_INI filter:authtoken auth_port $KEYSTONE_AUTH_PORT |
| 171 | iniset $CINDER_API_PASTE_INI filter:authtoken auth_protocol $KEYSTONE_AUTH_PROTOCOL |
| 172 | iniset $CINDER_API_PASTE_INI filter:authtoken admin_tenant_name $SERVICE_TENANT_NAME |
| 173 | iniset $CINDER_API_PASTE_INI filter:authtoken admin_user cinder |
| 174 | iniset $CINDER_API_PASTE_INI filter:authtoken admin_password $SERVICE_PASSWORD |
Akihiro MOTOKI | 5e3deb6 | 2012-12-11 17:09:02 +0900 | [diff] [blame] | 175 | iniset $CINDER_API_PASTE_INI filter:authtoken signing_dir $CINDER_AUTH_CACHE_DIR |
Dean Troyer | bc071bc | 2012-10-01 14:06:44 -0500 | [diff] [blame] | 176 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 177 | cp $CINDER_DIR/etc/cinder/cinder.conf.sample $CINDER_CONF |
| 178 | iniset $CINDER_CONF DEFAULT auth_strategy keystone |
John Griffith | 997c103 | 2013-03-05 23:01:38 +0000 | [diff] [blame] | 179 | iniset $CINDER_CONF DEFAULT debug True |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 180 | iniset $CINDER_CONF DEFAULT verbose True |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 181 | if [ "$CINDER_MULTI_LVM_BACKEND" = "True" ]; then |
| 182 | iniset $CINDER_CONF DEFAULT enabled_backends lvmdriver-1,lvmdriver-2 |
| 183 | iniset $CINDER_CONF lvmdriver-1 volume_group $VOLUME_GROUP |
| 184 | iniset $CINDER_CONF lvmdriver-1 volume_driver cinder.volume.drivers.lvm.LVMISCSIDriver |
| 185 | iniset $CINDER_CONF lvmdriver-1 volume_backend_name LVM_iSCSI |
| 186 | iniset $CINDER_CONF lvmdriver-2 volume_group $VOLUME_GROUP2 |
| 187 | iniset $CINDER_CONF lvmdriver-2 volume_driver cinder.volume.drivers.lvm.LVMISCSIDriver |
| 188 | iniset $CINDER_CONF lvmdriver-2 volume_backend_name LVM_iSCSI |
| 189 | else |
| 190 | iniset $CINDER_CONF DEFAULT volume_group $VOLUME_GROUP |
| 191 | iniset $CINDER_CONF DEFAULT volume_name_template ${VOLUME_NAME_PREFIX}%s |
| 192 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 193 | iniset $CINDER_CONF DEFAULT iscsi_helper tgtadm |
Attila Fazekas | 7e79d91 | 2013-03-03 12:23:04 +0100 | [diff] [blame] | 194 | iniset $CINDER_CONF DEFAULT sql_connection `database_connection_url cinder` |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 195 | iniset $CINDER_CONF DEFAULT api_paste_config $CINDER_API_PASTE_INI |
Joe Gordon | a58382a | 2013-02-20 12:45:02 -0800 | [diff] [blame] | 196 | iniset $CINDER_CONF DEFAULT rootwrap_config "$CINDER_CONF_DIR/rootwrap.conf" |
Dan Prince | 9f22f07 | 2013-01-28 09:53:38 -0500 | [diff] [blame] | 197 | iniset $CINDER_CONF DEFAULT osapi_volume_extension cinder.api.contrib.standard_extensions |
Dean Troyer | 50ac792 | 2012-09-13 14:02:01 -0500 | [diff] [blame] | 198 | iniset $CINDER_CONF DEFAULT state_path $CINDER_STATE_PATH |
John Griffith | 4e823ff | 2012-07-20 13:18:17 -0600 | [diff] [blame] | 199 | |
Dean Troyer | 560346b | 2012-12-13 17:05:24 -0600 | [diff] [blame] | 200 | if is_service_enabled tls-proxy; then |
| 201 | # Set the service port for a proxy to take the original |
| 202 | iniset $CINDER_CONF DEFAULT osapi_volume_listen_port $CINDER_SERVICE_PORT_INT |
| 203 | fi |
| 204 | |
Dean Troyer | 4d3049e | 2012-11-06 20:38:14 -0600 | [diff] [blame] | 205 | if [ "$SYSLOG" != "False" ]; then |
| 206 | iniset $CINDER_CONF DEFAULT use_syslog True |
| 207 | fi |
| 208 | |
Akihiro MOTOKI | b0f1c38 | 2013-01-13 17:58:12 +0900 | [diff] [blame] | 209 | iniset_rpc_backend cinder $CINDER_CONF DEFAULT |
Gary Kotton | f71bf19 | 2012-08-06 11:15:36 -0400 | [diff] [blame] | 210 | |
James E. Blair | 213c416 | 2012-11-06 09:38:36 +0100 | [diff] [blame] | 211 | if [[ "$CINDER_SECURE_DELETE" == "False" ]]; then |
| 212 | iniset $CINDER_CONF DEFAULT secure_delete False |
Pádraig Brady | eac9370 | 2013-01-02 16:02:54 +0000 | [diff] [blame] | 213 | iniset $CINDER_CONF DEFAULT volume_clear none |
James E. Blair | 213c416 | 2012-11-06 09:38:36 +0100 | [diff] [blame] | 214 | fi |
| 215 | |
Chmouel Boudjnah | 1057bff | 2012-08-03 11:42:51 +0000 | [diff] [blame] | 216 | if [ "$LOG_COLOR" == "True" ] && [ "$SYSLOG" == "False" ]; then |
| 217 | # Add color to logging output |
Joe Gordon | 07db713 | 2013-01-30 13:07:25 -0800 | [diff] [blame] | 218 | iniset $CINDER_CONF DEFAULT logging_context_format_string "%(asctime)s.%(msecs)03d %(color)s%(levelname)s %(name)s [[01;36m%(request_id)s [00;36m%(user_id)s %(project_id)s%(color)s] [01;35m%(instance)s%(color)s%(message)s[00m" |
| 219 | iniset $CINDER_CONF DEFAULT logging_default_format_string "%(asctime)s.%(msecs)03d %(color)s%(levelname)s %(name)s [[00;36m-%(color)s] [01;35m%(instance)s%(color)s%(message)s[00m" |
Chmouel Boudjnah | 1057bff | 2012-08-03 11:42:51 +0000 | [diff] [blame] | 220 | iniset $CINDER_CONF DEFAULT logging_debug_format_suffix "[00;33mfrom (pid=%(process)d) %(funcName)s %(pathname)s:%(lineno)d[00m" |
Joe Gordon | 07db713 | 2013-01-30 13:07:25 -0800 | [diff] [blame] | 221 | iniset $CINDER_CONF DEFAULT logging_exception_prefix "%(color)s%(asctime)s.%(msecs)03d TRACE %(name)s [01;35m%(instance)s[00m" |
Chmouel Boudjnah | 1057bff | 2012-08-03 11:42:51 +0000 | [diff] [blame] | 222 | fi |
Mate Lakat | b2fdafe | 2012-11-20 15:52:21 +0000 | [diff] [blame] | 223 | |
| 224 | if [ "$CINDER_DRIVER" == "XenAPINFS" ]; then |
| 225 | ( |
| 226 | set -u |
Mate Lakat | a0ca45f | 2012-12-06 17:45:49 +0000 | [diff] [blame] | 227 | iniset $CINDER_CONF DEFAULT volume_driver "cinder.volume.drivers.xenapi.sm.XenAPINFSDriver" |
Mate Lakat | b2fdafe | 2012-11-20 15:52:21 +0000 | [diff] [blame] | 228 | iniset $CINDER_CONF DEFAULT xenapi_connection_url "$CINDER_XENAPI_CONNECTION_URL" |
| 229 | iniset $CINDER_CONF DEFAULT xenapi_connection_username "$CINDER_XENAPI_CONNECTION_USERNAME" |
| 230 | iniset $CINDER_CONF DEFAULT xenapi_connection_password "$CINDER_XENAPI_CONNECTION_PASSWORD" |
| 231 | iniset $CINDER_CONF DEFAULT xenapi_nfs_server "$CINDER_XENAPI_NFS_SERVER" |
| 232 | iniset $CINDER_CONF DEFAULT xenapi_nfs_serverpath "$CINDER_XENAPI_NFS_SERVERPATH" |
| 233 | ) |
MORITA Kazutaka | af22a47 | 2013-01-17 16:16:25 +0900 | [diff] [blame] | 234 | elif [ "$CINDER_DRIVER" == "sheepdog" ]; then |
| 235 | iniset $CINDER_CONF DEFAULT volume_driver "cinder.volume.drivers.sheepdog.SheepdogDriver" |
Mate Lakat | b2fdafe | 2012-11-20 15:52:21 +0000 | [diff] [blame] | 236 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 237 | } |
| 238 | |
Dean Troyer | 671c16e | 2012-12-13 16:22:38 -0600 | [diff] [blame] | 239 | # create_cinder_accounts() - Set up common required cinder accounts |
| 240 | |
| 241 | # Tenant User Roles |
| 242 | # ------------------------------------------------------------------ |
| 243 | # service cinder admin # if enabled |
| 244 | |
| 245 | # Migrated from keystone_data.sh |
| 246 | create_cinder_accounts() { |
| 247 | |
| 248 | SERVICE_TENANT=$(keystone tenant-list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }") |
| 249 | ADMIN_ROLE=$(keystone role-list | awk "/ admin / { print \$2 }") |
| 250 | |
| 251 | # Cinder |
| 252 | if [[ "$ENABLED_SERVICES" =~ "c-api" ]]; then |
| 253 | CINDER_USER=$(keystone user-create \ |
| 254 | --name=cinder \ |
| 255 | --pass="$SERVICE_PASSWORD" \ |
| 256 | --tenant_id $SERVICE_TENANT \ |
| 257 | --email=cinder@example.com \ |
| 258 | | grep " id " | get_field 2) |
| 259 | keystone user-role-add \ |
| 260 | --tenant_id $SERVICE_TENANT \ |
| 261 | --user_id $CINDER_USER \ |
| 262 | --role_id $ADMIN_ROLE |
| 263 | if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then |
| 264 | CINDER_SERVICE=$(keystone service-create \ |
| 265 | --name=cinder \ |
| 266 | --type=volume \ |
| 267 | --description="Cinder Volume Service" \ |
| 268 | | grep " id " | get_field 2) |
| 269 | keystone endpoint-create \ |
| 270 | --region RegionOne \ |
| 271 | --service_id $CINDER_SERVICE \ |
Dean Troyer | 560346b | 2012-12-13 17:05:24 -0600 | [diff] [blame] | 272 | --publicurl "$CINDER_SERVICE_PROTOCOL://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v1/\$(tenant_id)s" \ |
| 273 | --adminurl "$CINDER_SERVICE_PROTOCOL://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v1/\$(tenant_id)s" \ |
| 274 | --internalurl "$CINDER_SERVICE_PROTOCOL://$CINDER_SERVICE_HOST:$CINDER_SERVICE_PORT/v1/\$(tenant_id)s" |
Dean Troyer | 671c16e | 2012-12-13 16:22:38 -0600 | [diff] [blame] | 275 | fi |
| 276 | fi |
| 277 | } |
| 278 | |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 279 | # create_cinder_cache_dir() - Part of the init_cinder() process |
| 280 | function create_cinder_cache_dir() { |
| 281 | # Create cache dir |
| 282 | sudo mkdir -p $CINDER_AUTH_CACHE_DIR |
| 283 | sudo chown $STACK_USER $CINDER_AUTH_CACHE_DIR |
| 284 | rm -f $CINDER_AUTH_CACHE_DIR/* |
| 285 | } |
| 286 | |
| 287 | create_cinder_volume_group() { |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 288 | # According to the CINDER_MULTI_LVM_BACKEND value, configure one or two default volumes |
| 289 | # group called ``stack-volumes`` (and ``stack-volumes2``) for the volume |
| 290 | # service if it (they) does (do) not yet exist. If you don't wish to use a |
| 291 | # file backed volume group, create your own volume group called ``stack-volumes`` |
| 292 | # and ``stack-volumes2`` before invoking ``stack.sh``. |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 293 | # |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 294 | # By default, the two backing files are 5G in size, and are stored in |
| 295 | # ``/opt/stack/data``. |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 296 | |
| 297 | if ! sudo vgs $VOLUME_GROUP; then |
| 298 | VOLUME_BACKING_FILE=${VOLUME_BACKING_FILE:-$DATA_DIR/${VOLUME_GROUP}-backing-file} |
| 299 | |
| 300 | # Only create if the file doesn't already exists |
| 301 | [[ -f $VOLUME_BACKING_FILE ]] || truncate -s $VOLUME_BACKING_FILE_SIZE $VOLUME_BACKING_FILE |
| 302 | |
| 303 | DEV=`sudo losetup -f --show $VOLUME_BACKING_FILE` |
| 304 | |
| 305 | # Only create if the loopback device doesn't contain $VOLUME_GROUP |
| 306 | if ! sudo vgs $VOLUME_GROUP; then |
| 307 | sudo vgcreate $VOLUME_GROUP $DEV |
| 308 | fi |
| 309 | fi |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 310 | if [ "$CINDER_MULTI_LVM_BACKEND" = "True" ]; then |
| 311 | #set up the second volume if CINDER_MULTI_LVM_BACKEND is enabled |
| 312 | |
| 313 | if ! sudo vgs $VOLUME_GROUP2; then |
| 314 | VOLUME_BACKING_FILE2=${VOLUME_BACKING_FILE2:-$DATA_DIR/${VOLUME_GROUP2}-backing-file} |
| 315 | |
| 316 | # Only create if the file doesn't already exists |
| 317 | [[ -f $VOLUME_BACKING_FILE2 ]] || truncate -s $VOLUME_BACKING_FILE_SIZE $VOLUME_BACKING_FILE2 |
| 318 | |
| 319 | DEV=`sudo losetup -f --show $VOLUME_BACKING_FILE2` |
| 320 | |
| 321 | # Only create if the loopback device doesn't contain $VOLUME_GROUP |
| 322 | if ! sudo vgs $VOLUME_GROUP2; then |
| 323 | sudo vgcreate $VOLUME_GROUP2 $DEV |
| 324 | fi |
| 325 | fi |
| 326 | fi |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 327 | |
| 328 | mkdir -p $CINDER_STATE_PATH/volumes |
| 329 | } |
| 330 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 331 | # init_cinder() - Initialize database and volume group |
| 332 | function init_cinder() { |
| 333 | # Force nova volumes off |
| 334 | NOVA_ENABLED_APIS=$(echo $NOVA_ENABLED_APIS | sed "s/osapi_volume,//") |
| 335 | |
Terry Wilson | 428af5a | 2012-11-01 16:12:39 -0400 | [diff] [blame] | 336 | if is_service_enabled $DATABASE_BACKENDS; then |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 337 | # (Re)create cinder database |
Terry Wilson | 428af5a | 2012-11-01 16:12:39 -0400 | [diff] [blame] | 338 | recreate_database cinder utf8 |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 339 | |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 340 | # Migrate cinder database |
Monty Taylor | 9fbeedd | 2012-08-17 12:52:27 -0400 | [diff] [blame] | 341 | $CINDER_BIN_DIR/cinder-manage db sync |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 342 | fi |
| 343 | |
| 344 | if is_service_enabled c-vol; then |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 345 | |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 346 | create_cinder_volume_group |
Chuck Short | 3f603d9 | 2012-07-28 13:28:33 -0500 | [diff] [blame] | 347 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 348 | if sudo vgs $VOLUME_GROUP; then |
Vincent Untz | 00011c0 | 2012-12-06 09:56:32 +0100 | [diff] [blame] | 349 | if is_fedora || is_suse; then |
| 350 | # service is not started by default |
Vincent Untz | 0230aa8 | 2012-06-14 08:51:01 +0200 | [diff] [blame] | 351 | start_service tgtd |
| 352 | fi |
| 353 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 354 | # Remove iscsi targets |
| 355 | sudo tgtadm --op show --mode target | grep $VOLUME_NAME_PREFIX | grep Target | cut -f3 -d ' ' | sudo xargs -n1 tgt-admin --delete || true |
Dean Troyer | 22853c1 | 2013-01-07 15:18:12 -0600 | [diff] [blame] | 356 | # Start with a clean volume group |
| 357 | _clean_volume_group $VOLUME_GROUP $VOLUME_NAME_PREFIX |
Jérôme Gallard | dda2b7a | 2013-02-22 17:28:10 +0100 | [diff] [blame] | 358 | if [ "$CINDER_MULTI_LVM_BACKEND" = "True" ]; then |
| 359 | _clean_volume_group $VOLUME_GROUP2 $VOLUME_NAME_PREFIX |
| 360 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 361 | fi |
| 362 | fi |
Dean Troyer | bc071bc | 2012-10-01 14:06:44 -0500 | [diff] [blame] | 363 | |
Dean Troyer | f03bafe | 2013-02-12 10:58:28 -0600 | [diff] [blame] | 364 | create_cinder_cache_dir |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 365 | } |
| 366 | |
| 367 | # install_cinder() - Collect source and prepare |
| 368 | function install_cinder() { |
| 369 | git_clone $CINDER_REPO $CINDER_DIR $CINDER_BRANCH |
| 370 | git_clone $CINDERCLIENT_REPO $CINDERCLIENT_DIR $CINDERCLIENT_BRANCH |
| 371 | } |
| 372 | |
Mate Lakat | a39caac | 2012-09-03 15:45:53 +0100 | [diff] [blame] | 373 | # apply config.d approach (e.g. Oneiric does not have this) |
| 374 | function _configure_tgt_for_config_d() { |
| 375 | if [[ ! -d /etc/tgt/conf.d/ ]]; then |
Attila Fazekas | b79574b | 2012-12-01 10:42:46 +0100 | [diff] [blame] | 376 | sudo mkdir -p /etc/tgt/conf.d |
Mate Lakat | a39caac | 2012-09-03 15:45:53 +0100 | [diff] [blame] | 377 | echo "include /etc/tgt/conf.d/*.conf" | sudo tee -a /etc/tgt/targets.conf |
| 378 | fi |
| 379 | } |
| 380 | |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 381 | # start_cinder() - Start running processes, including screen |
| 382 | function start_cinder() { |
| 383 | if is_service_enabled c-vol; then |
Attila Fazekas | b79574b | 2012-12-01 10:42:46 +0100 | [diff] [blame] | 384 | _configure_tgt_for_config_d |
| 385 | if [[ ! -f /etc/tgt/conf.d/stack.conf ]]; then |
| 386 | echo "include $CINDER_STATE_PATH/volumes/*" | sudo tee /etc/tgt/conf.d/stack.conf |
| 387 | fi |
Vincent Untz | c18b965 | 2012-12-04 12:36:34 +0100 | [diff] [blame] | 388 | if is_ubuntu; then |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 389 | # tgt in oneiric doesn't restart properly if tgtd isn't running |
| 390 | # do it in two steps |
| 391 | sudo stop tgt || true |
| 392 | sudo start tgt |
Vincent Untz | 00011c0 | 2012-12-06 09:56:32 +0100 | [diff] [blame] | 393 | elif is_fedora; then |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 394 | # bypass redirection to systemctl during restart |
| 395 | sudo /sbin/service --skip-redirect tgtd restart |
Vincent Untz | 00011c0 | 2012-12-06 09:56:32 +0100 | [diff] [blame] | 396 | elif is_suse; then |
| 397 | restart_service tgtd |
| 398 | else |
| 399 | # note for other distros: unstack.sh also uses the tgt/tgtd service |
| 400 | # name, and would need to be adjusted too |
| 401 | exit_distro_not_supported "restarting tgt" |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 402 | fi |
| 403 | fi |
| 404 | |
Monty Taylor | 9fbeedd | 2012-08-17 12:52:27 -0400 | [diff] [blame] | 405 | screen_it c-api "cd $CINDER_DIR && $CINDER_BIN_DIR/cinder-api --config-file $CINDER_CONF" |
| 406 | screen_it c-vol "cd $CINDER_DIR && $CINDER_BIN_DIR/cinder-volume --config-file $CINDER_CONF" |
| 407 | screen_it c-sch "cd $CINDER_DIR && $CINDER_BIN_DIR/cinder-scheduler --config-file $CINDER_CONF" |
Stephen Mulcahy | 67068ef | 2013-02-21 11:20:58 +0000 | [diff] [blame] | 408 | screen_it c-bak "cd $CINDER_DIR && $CINDER_BIN_DIR/cinder-backup --config-file $CINDER_CONF" |
Dean Troyer | 560346b | 2012-12-13 17:05:24 -0600 | [diff] [blame] | 409 | |
| 410 | # Start proxies if enabled |
| 411 | if is_service_enabled c-api && is_service_enabled tls-proxy; then |
| 412 | start_tls_proxy '*' $CINDER_SERVICE_PORT $CINDER_SERVICE_HOST $CINDER_SERVICE_PORT_INT & |
| 413 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 414 | } |
| 415 | |
Dean Troyer | 699a29f | 2012-09-10 14:10:27 -0500 | [diff] [blame] | 416 | # stop_cinder() - Stop running processes |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 417 | function stop_cinder() { |
Dean Troyer | 699a29f | 2012-09-10 14:10:27 -0500 | [diff] [blame] | 418 | # Kill the cinder screen windows |
Stephen Mulcahy | 67068ef | 2013-02-21 11:20:58 +0000 | [diff] [blame] | 419 | for serv in c-api c-bak c-sch c-vol; do |
Dean Troyer | 699a29f | 2012-09-10 14:10:27 -0500 | [diff] [blame] | 420 | screen -S $SCREEN_NAME -p $serv -X kill |
| 421 | done |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 422 | |
| 423 | if is_service_enabled c-vol; then |
Vincent Untz | 90dd96d | 2012-12-13 08:59:57 +0100 | [diff] [blame] | 424 | if is_ubuntu; then |
| 425 | stop_service tgt |
| 426 | else |
| 427 | stop_service tgtd |
| 428 | fi |
Dean Troyer | 67787e6 | 2012-05-02 11:48:15 -0500 | [diff] [blame] | 429 | fi |
| 430 | } |
Dean Troyer | 7903b79 | 2012-09-13 17:16:12 -0500 | [diff] [blame] | 431 | |
| 432 | # Restore xtrace |
| 433 | $XTRACE |
Sean Dague | 584d90e | 2013-03-29 14:34:53 -0400 | [diff] [blame^] | 434 | |
| 435 | # Local variables: |
| 436 | # mode: shell-script |
| 437 | # End: |