mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
CLOUDSTACK-10382: Fix cloud-get-vm-data-configdrive.in (#2688)
This commit is contained in:
parent
8798014ca8
commit
3af54ec1a8
@ -21,23 +21,28 @@ mountdir=$(mktemp -d)
|
|||||||
filepath=$mountdir/cloudstack
|
filepath=$mountdir/cloudstack
|
||||||
|
|
||||||
user_data=$filepath/userdata/user_data.txt
|
user_data=$filepath/userdata/user_data.txt
|
||||||
availability_zone=$filepath/metadata/availability_zone.txt
|
|
||||||
cloud_identifier=$filepath/metadata/cloud_identifier.txt
|
|
||||||
instance_id=$filepath/metadata/instance_id.txt
|
|
||||||
local_hostname=$filepath/metadata/local_hostname.txt
|
|
||||||
service_offering=$filepath/metadata/service_offering.txt
|
|
||||||
vm_id=$filepath/metadata/vm_id.txt
|
|
||||||
public_key=$filepath/metadata/public_keys.txt
|
|
||||||
vm_password=$filepath/password/vm_password.txt
|
vm_password=$filepath/password/vm_password.txt
|
||||||
|
|
||||||
|
declare -A metadata=(
|
||||||
|
["availability-zone"]=$filepath/metadata/availability-zone.txt
|
||||||
|
["cloud-identifier"]=$filepath/metadata/cloud-identifier.txt
|
||||||
|
["instance-id"]=$filepath/metadata/instance-id.txt
|
||||||
|
["local-hostname"]=$filepath/metadata/local-hostname.txt
|
||||||
|
["local-ipv4"]=$filepath/metadata/local-ipv4.txt
|
||||||
|
["public-ipv4"]=$filepath/metadata/public-ipv4.txt
|
||||||
|
["service-offering"]=$filepath/metadata/service-offering.txt
|
||||||
|
["vm-id"]=$filepath/metadata/vm-id.txt
|
||||||
|
["public-key"]=$filepath/metadata/public-keys.txt
|
||||||
|
)
|
||||||
# If lable name is other than config, please change the below line as required
|
# If lable name is other than config, please change the below line as required
|
||||||
DefaultDisk=/dev/disk/by-label/config-2
|
DefaultDisk=/dev/disk/by-label/config-2
|
||||||
|
|
||||||
function usage
|
function usage
|
||||||
{
|
{
|
||||||
|
keys=${!metadata[@]}
|
||||||
echo -e "USAGE: cloud-get-vm-data -options"
|
echo -e "USAGE: cloud-get-vm-data -options"
|
||||||
echo -e " where options include:"
|
echo -e " where options include:"
|
||||||
echo -e "\\t-m | --metadata [availability-zone | cloud-identifier | instance-id | local-hostname | service-offering | vm-id | public-key] \\n\\t\\tprint vm metadata"
|
echo -e "\\t-m | --metadata [${keys// / | }] \\n\\t\\tprint vm metadata"
|
||||||
echo -e "\\t-p | --password \\n\\t\\tprint vm password"
|
echo -e "\\t-p | --password \\n\\t\\tprint vm password"
|
||||||
echo -e "\\t-u | --userdata \\n\\t\\tprint vm userdata"
|
echo -e "\\t-u | --userdata \\n\\t\\tprint vm userdata"
|
||||||
}
|
}
|
||||||
@ -52,7 +57,7 @@ function prepare_mount
|
|||||||
if [ -e $DefaultDisk ]; then
|
if [ -e $DefaultDisk ]; then
|
||||||
Disk=$DefaultDisk
|
Disk=$DefaultDisk
|
||||||
else
|
else
|
||||||
BLOCK_DEVICE=$(blkid -t LABEL='config' /dev/hd? /dev/sd? /dev/xvd? -o device)
|
BLOCK_DEVICE=$(blkid -t LABEL='config-2' /dev/sr? /dev/hd? /dev/sd? /dev/xvd? -o device)
|
||||||
if [ -n $BLOCK_DEVICE ]; then
|
if [ -n $BLOCK_DEVICE ]; then
|
||||||
Disk=$BLOCK_DEVICE
|
Disk=$BLOCK_DEVICE
|
||||||
else
|
else
|
||||||
@ -81,34 +86,21 @@ case $1 in
|
|||||||
;;
|
;;
|
||||||
-m | --metadata ) shift
|
-m | --metadata ) shift
|
||||||
if [ "$1" != "" ]; then
|
if [ "$1" != "" ]; then
|
||||||
case $1 in
|
if [ -n "${metadata[$1]}" ]; then
|
||||||
availability-zone ) echo -n "availability zone: "; filename=$availability_zone
|
echo -n "$1: "
|
||||||
;;
|
filename=${metadata[$1]}
|
||||||
cloud-identifier ) echo -n "cloud identifier: "; filename=$cloud_identifier
|
else
|
||||||
;;
|
usage
|
||||||
instance-id ) echo -n "instance-id: "; filename=$instance_id
|
remove_mount
|
||||||
;;
|
exit 1
|
||||||
local-hostname ) echo -n "local-hostname: "; filename=$local_hostname
|
fi
|
||||||
;;
|
|
||||||
service-offering ) echo -n "service-offering: "; filename=$service_offering
|
|
||||||
;;
|
|
||||||
vm-id ) echo -n "vm-id: "; filename=$vm_id
|
|
||||||
;;
|
|
||||||
public-key ) echo -n "public-key: "; filename=$public_key
|
|
||||||
;;
|
|
||||||
* ) usage
|
|
||||||
remove_mount
|
|
||||||
exit 1
|
|
||||||
esac
|
|
||||||
else
|
else
|
||||||
echo -e "METADATA\\n"
|
echo -e "METADATA\\n"
|
||||||
[ -f $availability_zone ] && echo -e "availability zone:\t" "$(cat $availability_zone)"
|
for entry in "${!metadata[@]}"
|
||||||
[ -f $cloud_identifier ] && echo -e "cloud identifier:\t" "$(cat $cloud_identifier)"
|
do
|
||||||
[ -f $instance_id ] && echo -e "instance-id:\t\t" "$(cat $instance_id)"
|
file=${metadata[$entry]}
|
||||||
[ -f $local_hostname ] && echo -e "local-hostname:\t\t" "$(cat $local_hostname)"
|
[ -f $file ] && printf "%18s :\t%s\n" $entry "$(cat $file)"
|
||||||
[ -f $service_offering ] && echo -e "service-offering:\t" "$(cat $service_offering)"
|
done
|
||||||
[ -f $vm_id ] && echo -e "vm-id:\t\t\t" "$(cat $vm_id)"
|
|
||||||
[ -f $public_key ] && echo -e "public-key:\t\t" "$(cat $public_key)"
|
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
-p | --password ) echo -n "PASSWORD: "
|
-p | --password ) echo -n "PASSWORD: "
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user