100 lines
3.7 KiB
Bash
100 lines
3.7 KiB
Bash
#!/bin/bash
|
|
set -x
|
|
echo $*
|
|
export MDBCI_VM_PATH=${MDBCI_VM_PATH:-$HOME/vms}
|
|
export mdbci_dir=${mdbci_dir:-"$HOME/mdbci/"}
|
|
|
|
export config_name="$1"
|
|
if [ -z $1 ] ; then
|
|
config_name="test1"
|
|
fi
|
|
|
|
export curr_dir=`pwd`
|
|
|
|
export maxscale_binlog_dir="/var/lib/maxscale/Binlog_Service"
|
|
export maxdir="/usr/bin/"
|
|
export maxdir_bin="/usr/bin/"
|
|
export maxscale_cnf="/etc/maxscale.cnf"
|
|
export maxscale_log_dir="/var/log/maxscale/"
|
|
|
|
# Number of nodes
|
|
export galera_N=`cat "$MDBCI_VM_PATH/$config_name"_network_config | grep galera | grep network | wc -l`
|
|
export node_N=`cat "$MDBCI_VM_PATH/$config_name"_network_config | grep node | grep network | wc -l`
|
|
export maxscale_N=`cat "$MDBCI_VM_PATH/$config_name"_network_config | grep maxscale | grep network | wc -l`
|
|
sed "s/^/export /g" "$MDBCI_VM_PATH/$config_name"_network_config > "$curr_dir"/"$config_name"_network_config_export
|
|
source "$curr_dir"/"$config_name"_network_config_export
|
|
|
|
|
|
# User name and Password for Master/Slave replication setup (should have all PRIVILEGES)
|
|
export node_user="skysql"
|
|
export node_password="skysql"
|
|
|
|
# User name and Password for Galera setup (should have all PRIVILEGES)
|
|
export galera_user="skysql"
|
|
export galera_password="skysql"
|
|
|
|
export maxscale_user="skysql"
|
|
export maxscale_password="skysql"
|
|
|
|
export maxadmin_password="mariadb"
|
|
|
|
for prefix in "node" "galera" "maxscale"
|
|
do
|
|
N_var="$prefix"_N
|
|
Nx=${!N_var}
|
|
N=`expr $Nx - 1`
|
|
for i in $(seq 0 $N)
|
|
do
|
|
num=`printf "%03d" $i`
|
|
eval 'export "$prefix"_"$num"_port=3306'
|
|
eval 'export "$prefix"_"$num"_access_sudo=sudo'
|
|
|
|
start_cmd_var="$prefix"_"$num"_start_db_command
|
|
stop_cmd_var="$prefix"_"$num"_stop_db_command
|
|
mysql_exe=`${mdbci_dir}/mdbci ssh --command 'ls /etc/init.d/mysql* 2> /dev/null | tr -cd "[:print:]"' $config_name/node_$num --silent 2> /dev/null`
|
|
echo $mysql_exe | grep -i "mysql"
|
|
if [ $? != 0 ] ; then
|
|
service_name=`${mdbci_dir}/mdbci ssh --command 'systemctl list-unit-files | grep mysql' $config_name/node_$num --silent`
|
|
echo $service_name | grep mysql
|
|
if [ $? == 0 ] ; then
|
|
echo $service_name | grep mysqld
|
|
if [ $? == 0 ] ; then
|
|
eval 'export $start_cmd_var="service mysqld start "'
|
|
eval 'export $stop_cmd_var="service mysqld stop "'
|
|
else
|
|
eval 'export $start_cmd_var="service mysql start "'
|
|
eval 'export $stop_cmd_var="service mysql stop "'
|
|
fi
|
|
else
|
|
${mdbci_dir}/mdbci ssh --command 'echo \"/usr/sbin/mysqld \$* 2> stderr.log > stdout.log &\" > mysql_start.sh; echo \"sleep 20\" >> mysql_start.sh; echo \"disown\" >> mysql_start.sh; chmod a+x mysql_start.sh' $config_name/node_$num --silent
|
|
eval 'export $start_cmd_var="/home/$au/mysql_start.sh "'
|
|
eval 'export $stop_cmd_var="killall mysqld "'
|
|
fi
|
|
else
|
|
eval 'export $start_cmd_var="$mysql_exe start "'
|
|
eval 'export $stop_cmd_var="$mysql_exe stop "'
|
|
fi
|
|
|
|
eval 'export "$prefix"_"$num"_start_vm_command="cd ${MDBCI_VM_PATH}/$config_name;vagrant resume ${prefix}_$num ; cd $curr_dir"'
|
|
eval 'export "$prefix"_"$num"_stop_vm_command="cd ${MDBCI_VM_PATH}/$config_name;vagrant suspend ${prefix}_$num ; cd $curr_dir"'
|
|
done
|
|
done
|
|
|
|
export maxscale_access_user=$maxscale_000_whoami
|
|
export maxscale_access_sudo="sudo "
|
|
|
|
# IP Of MaxScale machine
|
|
export maxscale_IP=$maxscale_000_IP
|
|
export maxscale_sshkey=$maxscale_000_keyfile
|
|
|
|
# Sysbench directory (should be sysbench >= 0.5)
|
|
export sysbench_dir=${sysbench_dir:-"$HOME/sysbench_deb7/sysbench/"}
|
|
|
|
export ssl=true
|
|
|
|
export take_snapshot_command="${mdbci_dir}/mdbci snapshot take --path-to-nodes ${config_name} --snapshot-name "
|
|
export revert_snapshot_command="${mdbci_dir}/mdbci snapshot revert --path-to-nodes ${config_name} --snapshot-name "
|
|
#export use_snapshots=yes
|
|
|
|
set +x
|