71883bcd4c
Change-Id: Ifa4f7af2fe072585e611667c35d0d71830f410c5
225 lines
6.3 KiB
Bash
Executable File
225 lines
6.3 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
|
|
### Log the script all outputs locally
|
|
exec > >(sudo tee install.log)
|
|
exec 2>&1
|
|
|
|
### Creat a lock to avoid running multiple instances of script.
|
|
LOCKFILE="/tmp/`basename $0`"
|
|
LOCKFD=99
|
|
|
|
# PRIVATE
|
|
_lock() { flock -$1 $LOCKFD; }
|
|
_no_more_locking() { _lock u; _lock xn && rm -f $LOCKFILE; }
|
|
_prepare_locking() { eval "exec $LOCKFD>\"$LOCKFILE\""; trap _no_more_locking EXIT; }
|
|
|
|
# ON START
|
|
_prepare_locking
|
|
|
|
# PUBLIC
|
|
exlock_now() { _lock xn; } # obtain an exclusive lock immediately or fail
|
|
|
|
exlock_now || exit 1
|
|
|
|
### BEGIN OF SCRIPT ###
|
|
DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
|
source $DIR/install.conf
|
|
|
|
### Change selinux security policy
|
|
echo 0 > /selinux/enforce
|
|
|
|
### Add epel repo
|
|
sudo rpm -q epel-release
|
|
if [ "$?" != "0" ]; then
|
|
sudo rpm -Uvh http://download.fedoraproject.org/pub/epel/${IMAGE_VERSION_MAJOR}/${IMAGE_ARCH}/epel-release-6-8.noarch.rpm >& /dev/null
|
|
if [ "$?" != "0" ]; then
|
|
echo "failed to install epel-release"
|
|
exit 1
|
|
else
|
|
echo "sucessfaully installed epel-release"
|
|
fi
|
|
else
|
|
echo "epel-release is already installed"
|
|
fi
|
|
|
|
sed -i 's/^mirrorlist=https/mirrorlist=http/g' /etc/yum.repos.d/epel.repo
|
|
|
|
### Add atomic repo
|
|
sudo rpm -q atomic-release
|
|
if [ "$?" != "0" ]; then
|
|
sudo rpm -Uvh http://www6.atomicorp.com/channels/atomic/${IMAGE_TYPE,,}/${IMAGE_VERSION_MAJOR}/${IMAGE_ARCH}/RPMS/atomic-release-1.0-19.${IMAGE_TYPE_OTHER}${IMAGE_VERSION_MAJOR}.art.noarch.rpm >& /dev/null
|
|
if [ "$?" != "0" ]; then
|
|
echo "failed to install atomic-release"
|
|
exit 1
|
|
else
|
|
echo "successfully installed atomic-release"
|
|
fi
|
|
else
|
|
echo "atomic-release is already installed"
|
|
fi
|
|
|
|
sed -i 's/^mirrorlist=https/mirrorlist=http/g' /etc/yum.repos.d/atomic.repo
|
|
|
|
### Trap any error code with related filename and line.
|
|
errtrap()
|
|
{
|
|
FILE=${BASH_SOURCE[1]:-$BASH_SOURCE[0]}
|
|
echo "[FILE: "$(basename $FILE)", LINE: $1] Error: Command or function exited with status $2"
|
|
}
|
|
|
|
if [[ "$-" == *x* ]]; then
|
|
trap 'errtrap $LINENO $?' ERR
|
|
fi
|
|
|
|
# Install figlet
|
|
sudo yum -y install figlet >& /dev/null
|
|
if [[ "$?" != "0" ]]; then
|
|
echo "failed to install figlet"
|
|
exit 1
|
|
else
|
|
echo "figlet is installed"
|
|
fi
|
|
figlet -ctf slant Compass Installer
|
|
|
|
while [ $1 ]; do
|
|
flags=$1
|
|
param=${flags/'--'/''}
|
|
var=$(echo $param | cut -d"=" -f1)
|
|
val=$(echo $param | cut -d"=" -f2)
|
|
export $var=$val
|
|
shift
|
|
done
|
|
|
|
# convert ip address to int
|
|
ipaddr_convert()
|
|
{
|
|
ipaddr=$1
|
|
IFS=. read -r a b c d <<< "$ipaddr"
|
|
printf '%d\n' "$((a * 256 ** 3 + b * 256 ** 2 + c * 256 + d))"
|
|
}
|
|
|
|
# Load variables
|
|
loadvars()
|
|
{
|
|
varname=${1,,}
|
|
eval var=\$$(echo $1)
|
|
|
|
if [[ -z $var ]]; then
|
|
echo -e "\x1b[32mPlease enter the $varname (Example: $2):\x1b[37m"
|
|
while read input
|
|
do
|
|
if [ "$input" == "" ]; then
|
|
echo "Default $varname '$2' chosen"
|
|
export $(echo $1)="$2"
|
|
break
|
|
else
|
|
echo "You have entered $input"
|
|
export $(echo $1)="$input"
|
|
break
|
|
fi
|
|
done
|
|
fi
|
|
}
|
|
|
|
loadvars NIC "eth0"
|
|
sudo ifconfig $NIC
|
|
if [ $? -ne 0 ]; then
|
|
echo "There is no nic '$NIC' yet"
|
|
exit 1
|
|
fi
|
|
sudo ifconfig $NIC | grep 'inet addr:' >& /dev/null
|
|
if [ $? -ne 0 ]; then
|
|
echo "There is not any IP address assigned to the NIC '$NIC' yet, please assign an IP address first."
|
|
exit 1
|
|
fi
|
|
|
|
export netmask=$(ifconfig $NIC |grep Mask | cut -f 4 -d ':')
|
|
export ipaddr=$(ifconfig $NIC | grep 'inet addr:' | cut -d: -f2 | awk '{ print $1}')
|
|
export netaddr=$(ipcalc $ipaddr $netmask -n |cut -f 2 -d '=')
|
|
export netprefix=$(ipcalc $ipaddr $netmask -p |cut -f 2 -d '=')
|
|
loadvars SUBNET ${netaddr}/${netprefix}
|
|
ipcalc $SUBNET -c
|
|
if [ $? -ne 0 ]; then
|
|
echo "subnet $SUBNET format should be x.x.x.x/x"
|
|
exit 1
|
|
fi
|
|
export netaddr=$(ipcalc $SUBNET -n |cut -f 2 -d '=')
|
|
export netprefix=$(ipcalc $SUBNET -p |cut -f 2 -d '=')
|
|
export netmask=$(ipcalc $SUBNET -m |cut -f 2 -d '=')
|
|
export expected_subnet=${netaddr}/${netprefix}
|
|
if [[ "$SUBNET" != "$expected_subnet" ]]; then
|
|
echo "expected subnet should be $expected_subnet"
|
|
exit 1
|
|
fi
|
|
loadvars OPTION_ROUTER $(route -n | grep '^0.0.0.0' | xargs | cut -d ' ' -f 2)
|
|
ipcalc $OPTION_ROUTER -c
|
|
if [ $? -ne 0 ]; then
|
|
echo "router $OPTION_ROUTER format should be x.x.x.x"
|
|
exit 1
|
|
fi
|
|
export ip_start=$(echo "$ipaddr"|cut -f 1,2,3 -d '.')."100"
|
|
export ip_end=$(echo "$ipaddr"|cut -f 1,2,3 -d '.')."250"
|
|
loadvars IP_START "$ip_start"
|
|
ipcalc $IP_START -c
|
|
if [ $? -ne 0 ]; then
|
|
echo "ip start $IP_START format should be x.x.x.x"
|
|
exit 1
|
|
else
|
|
echo "ip start address is $IP_START"
|
|
fi
|
|
ip_start_net=$(ipcalc $IP_START $netmask -n |cut -f 2 -d '=')
|
|
if [[ "$ip_start_net" != "$netaddr" ]]; then
|
|
echo "ip start $IP_START is not in $SUBNET"
|
|
exit 1
|
|
fi
|
|
loadvars IP_END "$ip_end"
|
|
ipcalc $IP_END -c
|
|
if [ $? -ne 0 ]; then
|
|
echo "ip end $IP_END format should be x.x.x.x"
|
|
exit 1
|
|
fi
|
|
ip_end_net=$(ipcalc $IP_END $netmask -n |cut -f 2 -d '=')
|
|
if [[ "$ip_end_net" != "$netaddr" ]]; then
|
|
echo "ip end $IP_END is not in $SUBNET"
|
|
exit 1
|
|
fi
|
|
ip_start_int=$(ipaddr_convert $IP_START)
|
|
ip_end_int=$(ipaddr_convert $IP_END)
|
|
let ip_range=${ip_end_int}-${ip_start_int}
|
|
if [ $ip_range -le 0 ]; then
|
|
echo "there is no available ips to assign between $IP_START and $IP_END"
|
|
exit 1
|
|
fi
|
|
echo "there will be at most $ip_range hosts deployed."
|
|
loadvars NEXTSERVER $ipaddr
|
|
ipcalc $NEXTSERVER -c
|
|
if [ $? -ne 0 ]; then
|
|
echo "next server $NEXTSERVER format should be x.x.x.x"
|
|
exit 1
|
|
fi
|
|
loadvars NAMESERVER_DOMAINS "ods.com"
|
|
loadvars WEB_SOURCE 'http://git.openstack.org/stackforge/compass-web'
|
|
loadvars ADAPTERS_SOURCE 'http://git.openstack.org/stackforge/compass-adapters'
|
|
|
|
echo "script dir: $SCRIPT_DIR"
|
|
echo "compass dir is $COMPASSDIR"
|
|
|
|
echo "Install the Dependencies"
|
|
source ${COMPASSDIR}/install/dependency.sh || exit $?
|
|
|
|
echo "Prepare the Installation"
|
|
source ${COMPASSDIR}/install/prepare.sh || exit $?
|
|
|
|
echo "Install the OS Installer Tool"
|
|
source ${COMPASSDIR}/install/$OS_INSTALLER.sh || exit $?
|
|
|
|
echo "Install the Package Installer Tool"
|
|
source ${COMPASSDIR}/install/$PACKAGE_INSTALLER.sh || exit $?
|
|
|
|
echo "Download and Setup Compass and related services"
|
|
source ${COMPASSDIR}/install/compass.sh || exit $?
|
|
|
|
figlet -ctf slant Installation Complete!
|
|
echo -e "It takes\x1b[32m $SECONDS \x1b[0mseconds during the installation."
|