mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
156 lines
5.8 KiB
Bash
Executable File
156 lines
5.8 KiB
Bash
Executable File
#!/bin/bash
|
|
# Copyright 2012 Citrix Systems, Inc. Licensed under the
|
|
# Apache License, Version 2.0 (the "License"); you may not use this
|
|
# file except in compliance with the License. Citrix Systems, Inc.
|
|
# reserves all rights not expressly granted by the License.
|
|
# You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
# Automatically generated by addcopyright.py at 04/03/2012
|
|
|
|
|
|
# zucchini uses local storage, before setting up make sure
|
|
# * xen.public.network.device is set
|
|
# * use.local.storage and systemvm.use.local.storage are true
|
|
# * optionally turn off stats collector
|
|
# * expunge.delay and expunge.interval are 60s
|
|
# * capacity.skipcounting.hours=0
|
|
|
|
#Environment
|
|
#1. Small setup for zucchini : 13, 26, 39, 52 hosts only
|
|
#2. Only 3 host tags.
|
|
#5. simulator.properties, workers=1
|
|
|
|
usage() {
|
|
printf "Setup Zucchini Like Environment\nUsage: %s: -h management-server -z zoneid [-d delay] -n numberofhosts\n" $(basename $0) >&2
|
|
}
|
|
|
|
a=1 #CIDR - 16bytes
|
|
b=2 #CIDR - 8 bytes
|
|
|
|
#options
|
|
hflag=1
|
|
zflag=1
|
|
dflag=1
|
|
nflag=1
|
|
|
|
host="127.0.0.1" #default localhost
|
|
zoneid=
|
|
delay=300 #default 5 minutes
|
|
numberofhosts=13 #default 13 hosts
|
|
tag1="TAG1"
|
|
tag2="TAG2"
|
|
tag3="TAG3"
|
|
|
|
while getopts 'h:z:d:n:' OPTION
|
|
do
|
|
case $OPTION in
|
|
h) hflag=1
|
|
host="$OPTARG"
|
|
;;
|
|
z) zflag=1
|
|
zoneid="$OPTARG"
|
|
;;
|
|
d) dflag=1
|
|
delay="$OPTARG"
|
|
;;
|
|
n) nflag=1
|
|
numberofhosts="$OPTARG"
|
|
;;
|
|
?) usage
|
|
exit 2
|
|
;;
|
|
esac
|
|
done
|
|
|
|
if [ $hflag$zflag$dflag$nflag != "1111" ]
|
|
then
|
|
usage
|
|
exit 2
|
|
fi
|
|
|
|
if [ $numberofhosts -gt 52 ]
|
|
then
|
|
echo "Can't exceed 52 hosts"
|
|
exit 130
|
|
fi
|
|
|
|
numberofpods=3 #130 hosts per pod. So need only 3. each pod is homogenous
|
|
tag_one_range=$(($numberofhosts*5/13))
|
|
tag_two_range=$(($numberofhosts*2/13))
|
|
tag_three_range=$(($numberofhosts-$tag_one_range-$tag_two_range))
|
|
|
|
#create the zone
|
|
zone_query="GET http://$host/client/?command=createZone&networktype=Basic&securitygroupenabled=true&name=Zucchini&dns1=4.2.2.2&internaldns1=4.2.2.2 HTTP/1.0\n\n"
|
|
echo -e $zone_query | nc -v -w $delay $host 8096
|
|
|
|
sstor_query="GET http://$host/client/?command=addSecondaryStorage&zoneid=$zoneid&url=nfs://172.16.15.32/export/share/secondary HTTP/1.0\n\n"
|
|
echo -e $sstor_query | nc -v -w $delay $host 8096
|
|
|
|
let x=a
|
|
let y=b
|
|
for name in `seq 1 $numberofpods`
|
|
do
|
|
pod_query="GET http://$host/client/?command=createPod&zoneId=$zoneid&name=POD$name&netmask=255.255.255.0&startIp=172.$x.$y.2&endIp=172.$x.$y.131&gateway=172.$x.$y.1 HTTP/1.0\n\n"
|
|
vlan_query="GET http://$host/client/?command=createVlanIpRange&vlan=untagged&zoneid=$zoneid&podId=$name&forVirtualNetwork=false&gateway=172.$y.$x.1&netmask=255.255.255.0&startip=172.$y.$x.2&endip=172.$y.$x.131 HTTP/1.0\n\n"
|
|
echo -e $pod_query | nc -v -w $delay $host 8096
|
|
echo -e $vlan_query | nc -v -w $delay $host 8096
|
|
|
|
let x+=1
|
|
let y+=1
|
|
done
|
|
|
|
#add clusters -
|
|
#for i in `seq 1 10`
|
|
# cluster_query="GET http://$host/client/?command=addCluster&hypervisor=Simulator&clustertype=CloudManaged&zoneId=$zoneid&podId=$podid&clustername=POD$podid-CLUSTER$cluster HTTP/1.0\n\n"
|
|
# echo -e $cluster_query | nc -v -w $delay $host 8096
|
|
#do
|
|
|
|
clusterid=1
|
|
#TAG1
|
|
for cluster in `seq 1 $tag_one_range`
|
|
do
|
|
cluster_query="GET http://$host/client/?command=addCluster&hypervisor=Simulator&clustertype=CloudManaged&zoneId=$zoneid&podId=1&clustername=POD1-CLUSTER$cluster HTTP/1.0\n\n"
|
|
echo -e $cluster_query | nc -v -w $delay $host 8096
|
|
host_query="GET http://$host/client/?command=addHost&zoneId=$zoneid&podId=1&username=sim&password=sim&clusterid=$clusterid&url=http%3A%2F%2Fsim&hypervisor=Simulator&clustertype=CloudManaged&hosttags=$tag1 HTTP/1.0\n\n"
|
|
echo -e $host_query | nc -v -w $delay $host 8096
|
|
let clusterid+=1
|
|
done
|
|
|
|
#TAG2
|
|
for cluster in `seq $(($tag_one_range + 1)) $(($tag_one_range + $tag_two_range))`
|
|
do
|
|
cluster_query="GET http://$host/client/?command=addCluster&hypervisor=Simulator&clustertype=CloudManaged&zoneId=$zoneid&podId=2&clustername=POD2-CLUSTER$cluster HTTP/1.0\n\n"
|
|
echo -e $cluster_query | nc -v -w $delay $host 8096
|
|
host_query="GET http://$host/client/?command=addHost&zoneId=$zoneid&podId=2&username=sim&password=sim&clusterid=$clusterid&url=http%3A%2F%2Fsim&hypervisor=Simulator&clustertype=CloudManaged&hosttags=$tag2 HTTP/1.0\n\n"
|
|
echo -e $host_query | nc -v -w $delay $host 8096
|
|
let clusterid+=1
|
|
done
|
|
|
|
#TAG3
|
|
for cluster in `seq $(($tag_two_range + $tag_one_range + 1)) $(($tag_three_range + $tag_two_range + $tag_one_range))`
|
|
do
|
|
cluster_query="GET http://$host/client/?command=addCluster&hypervisor=Simulator&clustertype=CloudManaged&zoneId=$zoneid&podId=3&clustername=POD3-CLUSTER$cluster HTTP/1.0\n\n"
|
|
echo -e $cluster_query | nc -v -w $delay $host 8096
|
|
host_query="GET http://$host/client/?command=addHost&zoneId=$zoneid&podId=3&username=sim&password=sim&clusterid=$clusterid&url=http%3A%2F%2Fsim&hypervisor=Simulator&clustertype=CloudManaged&hosttags=$tag3 HTTP/1.0\n\n"
|
|
echo -e $host_query | nc -v -w $delay $host 8096
|
|
let clusterid+=1
|
|
|
|
done
|
|
|
|
for i in {1..60}
|
|
do
|
|
sg_create_query="GET http://$host/client/?command=createSecurityGroup&name=TestGroup1&description=Test HTTP/1.0\n\n"
|
|
echo -e $sg_create_query | nc -v -w $delay $host 8096
|
|
|
|
sg_auth_query="GET http://$host/client/?command=authorizeSecurityGroupIngress&domainid=1&account=admin&securitygroupid=$((i+2))&protocol=TCP&startport=2002&endport=2002&usersecuritygrouplist[0].account=admin&usersecuritygrouplist[0].group=TestGroup1 HTTP/1.0\n\n"
|
|
echo -e $sg_create_query | nc -v -w $delay $host 8096
|
|
done
|
|
|
|
echo "Setup complete"
|
|
exit 0
|