summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNarinder Gupta <narinder.gupta@canonical.com>2016-11-02 04:51:23 -0500
committerNarinder Gupta <narinder.gupta@canonical.com>2016-11-02 12:55:58 -0500
commit1e29dbbb3bfb71fa4c79a67dcd07b9cddca63ac2 (patch)
tree4981fa02b62a0d9e01241b40a7d43909790c7e8c
parentcb2c19c322d2c798bfa28ad719240ef3341f4498 (diff)
modified to have better support of maas 2.0
Change-Id: Ie1298f2c2ccc04e0bb63a9303712d1a16b3f066c Signed-off-by: Narinder Gupta <narinder.gupta@canonical.com>
-rwxr-xr-xci/03-maasdeploy.sh88
-rwxr-xr-xci/clean.sh6
-rwxr-xr-xci/cleanvm.sh4
-rw-r--r--labconfig/default/deployconfig.yaml2
-rw-r--r--labconfig/default/deployment.yaml2
-rw-r--r--labconfig/default/labconfig.yaml2
6 files changed, 58 insertions, 46 deletions
diff --git a/ci/03-maasdeploy.sh b/ci/03-maasdeploy.sh
index dfb3167a..7239c027 100755
--- a/ci/03-maasdeploy.sh
+++ b/ci/03-maasdeploy.sh
@@ -5,7 +5,12 @@ set -ex
virtinstall=0
labname=$1
+if [ ! -e $HOME/.ssh/id_rsa ]; then
+ ssh-keygen -N '' -f $HOME/.ssh/id_rsa
+fi
+
API_SERVER="http://192.168.122.1/MAAS/api/2.0"
+API_SERVERMAAS="http://192.168.122.1/MAAS/"
PROFILE=ubuntu
MY_UPSTREAM_DNS=192.168.122.1
SSH_KEY=`cat ~/.ssh/id_rsa.pub`
@@ -15,6 +20,8 @@ SOURCE_ID=1
FABRIC_ID=1
VLAN_TAG=""
PRIMARY_RACK_CONTROLLER="192.168.122.1"
+SUBNET_CIDR="192.168.122.0/24"
+VLAN_TAG="untagged"
#install the packages needed
sudo apt-add-repository ppa:juju/stable -y
@@ -22,17 +29,16 @@ sudo apt-add-repository ppa:maas/stable -y
sudo apt-add-repository cloud-archive:newton -y
sudo apt-get update -y
sudo apt-get dist-upgrade -y
-sudo pip install --upgrade pip
sudo apt-get install openssh-server bzr git juju virtinst qemu-kvm libvirt-bin \
- maas-cli python-pip python-psutil python-openstackclient \
- python-congressclient gsutil charm-tools pastebinit -y
+ maas maas-region-controller python-pip python-psutil python-openstackclient \
+ python-congressclient gsutil charm-tools pastebinit python-jinja2 -y
+
+sudo pip install --upgrade pip
#first parameter should be custom and second should be either
# absolute location of file (including file name) or url of the
# file to download.
-labname=$1
-labfile=$2
#
# Config preparation
@@ -55,6 +61,7 @@ case "$labname" in
cp maas/juniper/pod1/deployment.yaml ./deployment.yaml
;;
'custom')
+ labfile=$2
if [ -e $labfile ]; then
cp $labfile ./labconfig.yaml || true
else
@@ -105,10 +112,6 @@ else
sudo mv 90-joid-init /etc/sudoers.d/
fi
-if [ ! -e $HOME/.ssh/id_rsa ]; then
- ssh-keygen -N '' -f $HOME/.ssh/id_rsa
-fi
-
echo "... Deployment of maas Started ...."
#
@@ -148,11 +151,13 @@ mkdir ~/.juju/ || true
sudo mkdir -p ~maas
sudo chown maas:maas ~maas
-sudo -u maas ssh-keygen -N '' -f ~maas/.ssh/id_rsa
+if [ ! -e ~maas/.ssh/id_rsa ]; then
+ sudo -u maas ssh-keygen -N '' -f ~maas/.ssh/id_rsa
+fi
+
# Ensure virsh can connect without ssh auth
sudo cat ~maas/.ssh/id_rsa.pub >> $HOME/.ssh/authorized_keys
-sudo cat HOME/.ssh/id_rsa.pub >> $HOME/.ssh/authorized_keys
-sudo -u maas virsh -c qemu+ssh://ubuntu@192.168.122.1/system list --all
+sudo cat $HOME/.ssh/id_rsa.pub >> $HOME/.ssh/authorized_keys
#
# MAAS deploy
@@ -177,16 +182,14 @@ configuremaas(){
maas $PROFILE boot-source update $SOURCE_ID \
url=$URL keyring_filename=$KEYRING_FILE
maas $PROFILE boot-source-selections create 1 \
- release='xenial' arches='amd64' labels='release' \
- os='ubuntu' subarches='*'
- maas $PROFILE boot-source-selections create 1 \
- release='trusty' arches='amd64' labels='release' \
+ release='trusty' arches='amd64' labels='daily' \
os='ubuntu' subarches='*'
maas $PROFILE boot-resources import
- COUNTER=0
- while [ $COUNTER -eq 0 ]; do
- COUNTER=`maas $PROFILE boot-resources read | grep xenial | wc -l`
- let COUNTER=COUNTER+1
+
+ while [ "$(maas $PROFILE boot-resources read | grep trusty | wc -l )" -le 0 ];
+ do
+ maas $PROFILE boot-resources import
+ sleep 20
done
IP_STATIC_RANGE_LOW="192.168.122.1"
@@ -195,21 +198,24 @@ configuremaas(){
start_ip=$IP_STATIC_RANGE_LOW end_ip=$IP_STATIC_RANGE_HIGH \
comment='This is a reserved range'
-# IP_DYNAMIC_RANGE_LOW="192.168.122.50"
-# IP_DYNAMIC_RANGE_HIGH="192.168.122.240"
-# maas $PROFILE ipranges create type=dynamic \
-# start_ip=$IP_DYNAMIC_RANGE_LOW end_ip=$IP_DYNAMIC_RANGE_HIGH \
-# comment='This is a reserved dynamic range'
+ IP_DYNAMIC_RANGE_LOW="192.168.122.50"
+ IP_DYNAMIC_RANGE_HIGH="192.168.122.80"
+ maas $PROFILE ipranges create type=dynamic \
+ start_ip=$IP_DYNAMIC_RANGE_LOW end_ip=$IP_DYNAMIC_RANGE_HIGH \
+ comment='This is a reserved dynamic range'
+
+ FABRIC_ID=$(maas $PROFILE subnet read $SUBNET_CIDR \
+ | grep fabric | cut -d ' ' -f 10 | cut -d '"' -f 2)
+
+ PRIMARY_RACK_CONTROLLER=`maas $PROFILE rack-controllers read | grep system_id | cut -d '"' -f 4`
- maas $PROFILE vlan update $FABRIC_ID $VLAN_TAG dhcp_on=True \
- primary_rack=$PRIMARY_RACK_CONTROLLER
+ maas $PROFILE vlan update $FABRIC_ID $VLAN_TAG dhcp_on=True primary_rack=$PRIMARY_RACK_CONTROLLER
SUBNET_CIDR="192.168.122.0/24"
MY_GATEWAY="192.168.122.1"
MY_NAMESERVER=192.168.122.1
maas $PROFILE subnet update $SUBNET_CIDR gateway_ip=$MY_GATEWAY
maas $PROFILE subnet update $SUBNET_CIDR dns_servers=$MY_NAMESERVER
- maas $PROFILE sshkeys create key="`cat $HOME/.ssh/id_rsa.pub`"
maas $PROFILE tags create name='bootstrap'
maas $PROFILE tags create name='compute'
@@ -218,7 +224,7 @@ configuremaas(){
}
addnodes(){
- virt-install --connect qemu:///system --name bootstrap --ram 2048 --vcpus 2 --video \
+ sudo virt-install --connect qemu:///system --name bootstrap --ram 2048 --vcpus 2 --video \
cirrus --arch x86_64 --disk size=20,format=qcow2,bus=virtio,io=native,pool=default \
--network bridge=virbr0,model=virtio --boot network,hd,menu=off --noautoconsole \
--vnc --print-xml | tee bootstrap
@@ -235,14 +241,16 @@ addnodes(){
maas $PROFILE tag update-nodes bootstrap add=$bootstrapid
}
-sudo chown $USER:$USER environments.yaml
+configuremaas
+addnodes
+#sudo chown $USER:$USER environments.yaml
echo "... Deployment of maas finish ...."
# Backup deployment.yaml and deployconfig.yaml in .juju folder
-cp ./environments.yaml ~/.juju/
-cp ./environments.yaml ~/joid_config/
+#cp ./environments.yaml ~/.juju/
+#cp ./environments.yaml ~/joid_config/
if [ -e ./deployconfig.yaml ]; then
cp ./deployconfig.yaml ~/.juju/
@@ -269,7 +277,7 @@ if [ "$virtinstall" -eq 1 ]; then
sudo virt-install --connect qemu:///system --name node5-compute --ram 8192 --vcpus 4 --disk size=120,format=qcow2,bus=virtio,io=native,pool=default --network bridge=virbr0,model=virtio --network bridge=virbr0,model=virtio --boot network,hd,menu=off --noautoconsole --vnc --print-xml | tee node5-compute
- node1controlmac=`grep "mac address" node1-control | head -1 | cut -d '"'-f 2`
+ node1controlmac=`grep "mac address" node1-control | head -1 | cut -d '"' -f 2`
node2computemac=`grep "mac address" node2-compute | head -1 | cut -d '"' -f 2`
node5computemac=`grep "mac address" node5-compute | head -1 | cut -d '"' -f 2`
@@ -339,27 +347,28 @@ crnodevlanint() {
#function for JUJU envronment
addcredential() {
- controllername=`awk 'NR==1{print $2}' environments.yaml`
- cloudname=`awk 'NR==1{print $2}' environments.yaml`
+ API_KEY=`sudo maas-region apikey --username=ubuntu`
+ controllername=`awk 'NR==1{print substr($1, 1, length($1)-1)}' deployment.yaml`
+ cloudname=`awk 'NR==1{print substr($1, 1, length($1)-1)}' deployment.yaml`
echo "credentials:" > credential.yaml
echo " $controllername:" >> credential.yaml
echo " opnfv-credentials:" >> credential.yaml
echo " auth-type: oauth1" >> credential.yaml
- echo " maas-oauth: $apikey" >> credential.yaml
+ echo " maas-oauth: $API_KEY" >> credential.yaml
juju add-credential $controllername -f credential.yaml --replace
}
addcloud() {
- controllername=`awk 'NR==1{print $2}' environments.yaml`
- cloudname=`awk 'NR==1{print $2}' environments.yaml`
+ controllername=`awk 'NR==1{print substr($1, 1, length($1)-1)}' deployment.yaml`
+ cloudname=`awk 'NR==1{print substr($1, 1, length($1)-1)}' deployment.yaml`
echo "clouds:" > maas-cloud.yaml
echo " $cloudname:" >> maas-cloud.yaml
echo " type: maas" >> maas-cloud.yaml
echo " auth-types: [oauth1]" >> maas-cloud.yaml
- echo " endpoint: http://$maas_ip/MAAS" >> maas-cloud.yaml
+ echo " endpoint: $API_SERVERMAAS" >> maas-cloud.yaml
juju add-cloud $cloudname maas-cloud.yaml --replace
}
@@ -394,6 +403,7 @@ elif [ -e ~/.juju/deployconfig.yaml ]; then
cp ~/.juju/deployconfig.yaml ./deployconfig.yaml
fi
+if [ -e ./deployconfig.yaml ]; then
enableiflist=`grep "interface-enable" deployconfig.yaml | cut -d ' ' -f 4 `
datanet=`grep "dataNetwork" deployconfig.yaml | cut -d ' ' -f 4 | sed -e 's/ //'`
stornet=`grep "storageNetwork" deployconfig.yaml | cut -d ' ' -f 4 | sed -e 's/ //'`
diff --git a/ci/clean.sh b/ci/clean.sh
index 0cd20761..eaff136b 100755
--- a/ci/clean.sh
+++ b/ci/clean.sh
@@ -10,8 +10,8 @@ fi
jujuver=`juju --version`
if [[ "$jujuver" > "2" ]]; then
- controllername=`awk 'NR==1{print $2}' environments.yaml`
- cloudname=`awk 'NR==1{print $2}' environments.yaml`
+ controllername=`awk 'NR==1{print substr($1, 1, length($1)-1)}' deployment.yaml`
+ cloudname=`awk 'NR==1{print substr($1, 1, length($1)-1)}' deployment.yaml`
juju kill-controller $controllername --timeout 10s -y || true
rm -rf precise
rm -rf trusty
@@ -37,3 +37,5 @@ elif [ -d $HOME/.juju/environments ]; then
sudo sysctl -w vm.drop_caches=3
fi
+#sudo apt-get purge maas maas-cli maas-common maas-dhcp maas-dns maas-proxy maas-rack-controller maas-region-api maas-region-controller -y
+#sudo rm -rf /var/lib/maas
diff --git a/ci/cleanvm.sh b/ci/cleanvm.sh
index c9acc90b..8259347c 100755
--- a/ci/cleanvm.sh
+++ b/ci/cleanvm.sh
@@ -20,4 +20,8 @@ sudo virsh undefine node2-compute || true
sudo virsh undefine node5-compute || true
sudo rm -rf /var/lib/libvirt/images/node1-control.img /var/lib/libvirt/images/node2-compute.img /var/lib/libvirt/images/node3-control.img /var/lib/libvirt/images/node4-control.img /var/lib/libvirt/images/node5-compute.img || true
+#sudo virsh destroy bootstrap || true
+#sudo virsh undefine bootstrap || true
+#sudo rm -rf /var/lib/libvirt/images/bootstrap.img || true
+
echo " Cleanup Finished ..."
diff --git a/labconfig/default/deployconfig.yaml b/labconfig/default/deployconfig.yaml
index f26fb080..12f82162 100644
--- a/labconfig/default/deployconfig.yaml
+++ b/labconfig/default/deployconfig.yaml
@@ -21,7 +21,7 @@ opnfv:
- disk: /srv
type: ceph
storageNetwork: ''
- units: 5
+ units: 3
vip:
ceilometer: 192.168.122.24
cinder: 192.168.122.29
diff --git a/labconfig/default/deployment.yaml b/labconfig/default/deployment.yaml
index 29e2d2a6..f56a9b2b 100644
--- a/labconfig/default/deployment.yaml
+++ b/labconfig/default/deployment.yaml
@@ -1,5 +1,3 @@
-# This file defines the deployment for the MAAS environment which is to be
-# deployed and automated.
demo-maas:
# Contains the virtual machine parameters for creating the Juju bootstrap
# node virtual machine
diff --git a/labconfig/default/labconfig.yaml b/labconfig/default/labconfig.yaml
index dacd5879..59a78569 100644
--- a/labconfig/default/labconfig.yaml
+++ b/labconfig/default/labconfig.yaml
@@ -1,5 +1,3 @@
-# This file defines the deployment for the MAAS environment which is to be
-# deployed and automated.
demo-maas:
# Contains the virtual machine parameters for creating the Juju bootstrap
# node virtual machine