|
|
|
@ -43,6 +43,39 @@ which ()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
sleep_until_file_deleted ()
|
|
|
|
|
{
|
|
|
|
|
file=$1
|
|
|
|
|
loop=$SLEEP_TIME
|
|
|
|
|
while (test $loop -gt 0)
|
|
|
|
|
do
|
|
|
|
|
sleep 1
|
|
|
|
|
if [ ! -f $file ]
|
|
|
|
|
then
|
|
|
|
|
return
|
|
|
|
|
fi
|
|
|
|
|
loop=`expr $loop - 1`
|
|
|
|
|
done
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sleep_until_file_exists ()
|
|
|
|
|
{
|
|
|
|
|
file=$1
|
|
|
|
|
loop=60 # Should be long enough enough for all cases
|
|
|
|
|
while (test $loop -gt 0)
|
|
|
|
|
do
|
|
|
|
|
sleep 1
|
|
|
|
|
if [ -f $file ]
|
|
|
|
|
then
|
|
|
|
|
return
|
|
|
|
|
fi
|
|
|
|
|
loop=`expr $loop - 1`
|
|
|
|
|
done
|
|
|
|
|
echo "ERROR: $file was not created in 60 seconds; Aborting"
|
|
|
|
|
exit 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# No paths below as we can't be sure where the program is!
|
|
|
|
|
|
|
|
|
|
BASENAME=`which basename | head -1`
|
|
|
|
@ -139,7 +172,7 @@ DO_GCOV=""
|
|
|
|
|
DO_GDB=""
|
|
|
|
|
DO_DDD=""
|
|
|
|
|
DO_CLIENT_GDB=""
|
|
|
|
|
SLEEP_TIME=2
|
|
|
|
|
SLEEP_TIME=10
|
|
|
|
|
CHARACTER_SET=latin1
|
|
|
|
|
DBUSER=""
|
|
|
|
|
START_WAIT_TIMEOUT=3
|
|
|
|
@ -503,19 +536,17 @@ mysql_install_db () {
|
|
|
|
|
|
|
|
|
|
for slave_num in 1 2 ;
|
|
|
|
|
do
|
|
|
|
|
rm -rf var/slave$slave_num-data/
|
|
|
|
|
$RM -rf var/slave$slave_num-data/
|
|
|
|
|
mkdir -p var/slave$slave_num-data/mysql
|
|
|
|
|
mkdir -p var/slave$slave_num-data/test
|
|
|
|
|
cp var/slave-data/mysql/* var/slave$slave_num-data/mysql
|
|
|
|
|
done
|
|
|
|
|
# Give mysqld some time to die.
|
|
|
|
|
sleep $SLEEP_TIME
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
gprof_prepare ()
|
|
|
|
|
{
|
|
|
|
|
rm -rf $GPROF_DIR
|
|
|
|
|
$RM -rf $GPROF_DIR
|
|
|
|
|
mkdir -p $GPROF_DIR
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -575,7 +606,7 @@ start_manager()
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
rm -f $MANAGER_PID_FILE
|
|
|
|
|
$RM -f $MANAGER_PID_FILE
|
|
|
|
|
MYSQL_MANAGER_PW=`$MYSQL_MANAGER_PWGEN -u $MYSQL_MANAGER_USER \
|
|
|
|
|
-o $MYSQL_MANAGER_PW_FILE`
|
|
|
|
|
$MYSQL_MANAGER --log=$MYSQL_MANAGER_LOG --port=$MYSQL_MANAGER_PORT \
|
|
|
|
@ -646,181 +677,186 @@ EOF
|
|
|
|
|
|
|
|
|
|
start_master()
|
|
|
|
|
{
|
|
|
|
|
if [ x$MASTER_RUNNING = x1 ] || [ x$LOCAL_MASTER = x1 ] ; then
|
|
|
|
|
return
|
|
|
|
|
fi
|
|
|
|
|
# Remove old berkeley db log files that can confuse the server
|
|
|
|
|
$RM -f $MASTER_MYDDIR/log.*
|
|
|
|
|
# Remove stale binary logs
|
|
|
|
|
$RM -f $MYSQL_TEST_DIR/var/log/master-bin.*
|
|
|
|
|
#run master initialization shell script if one exists
|
|
|
|
|
if [ -f "$master_init_script" ] ;
|
|
|
|
|
then
|
|
|
|
|
/bin/sh $master_init_script
|
|
|
|
|
fi
|
|
|
|
|
cd $BASEDIR # for gcov
|
|
|
|
|
#start master
|
|
|
|
|
if [ -z "$DO_BENCH" ]
|
|
|
|
|
then
|
|
|
|
|
master_args="--no-defaults --log-bin=$MYSQL_TEST_DIR/var/log/master-bin \
|
|
|
|
|
--server-id=1 --rpl-recovery-rank=1 \
|
|
|
|
|
--basedir=$MY_BASEDIR --init-rpl-role=master \
|
|
|
|
|
--port=$MASTER_MYPORT \
|
|
|
|
|
--exit-info=256 \
|
|
|
|
|
--core \
|
|
|
|
|
--datadir=$MASTER_MYDDIR \
|
|
|
|
|
--pid-file=$MASTER_MYPID \
|
|
|
|
|
--socket=$MASTER_MYSOCK \
|
|
|
|
|
--log=$MASTER_MYLOG \
|
|
|
|
|
--character-sets-dir=$CHARSETSDIR \
|
|
|
|
|
--default-character-set=$CHARACTER_SET \
|
|
|
|
|
--tmpdir=$MYSQL_TMP_DIR \
|
|
|
|
|
--language=$LANGUAGE \
|
|
|
|
|
--innodb_data_file_path=ibdata1:50M \
|
|
|
|
|
$SMALL_SERVER \
|
|
|
|
|
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT"
|
|
|
|
|
else
|
|
|
|
|
master_args="--no-defaults --log-bin=$MYSQL_TEST_DIR/var/log/master-bin \
|
|
|
|
|
--server-id=1 --rpl-recovery-rank=1 \
|
|
|
|
|
--basedir=$MY_BASEDIR --init-rpl-role=master \
|
|
|
|
|
--port=$MASTER_MYPORT \
|
|
|
|
|
--datadir=$MASTER_MYDDIR \
|
|
|
|
|
--pid-file=$MASTER_MYPID \
|
|
|
|
|
--socket=$MASTER_MYSOCK \
|
|
|
|
|
--character-sets-dir=$CHARSETSDIR \
|
|
|
|
|
--default-character-set=$CHARACTER_SET \
|
|
|
|
|
--core \
|
|
|
|
|
--tmpdir=$MYSQL_TMP_DIR \
|
|
|
|
|
--language=$LANGUAGE \
|
|
|
|
|
--innodb_data_file_path=ibdata1:50M \
|
|
|
|
|
$SMALL_SERVER \
|
|
|
|
|
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT"
|
|
|
|
|
fi
|
|
|
|
|
if [ x$MASTER_RUNNING = x1 ] || [ x$LOCAL_MASTER = x1 ] ; then
|
|
|
|
|
return
|
|
|
|
|
fi
|
|
|
|
|
# Remove old berkeley db log files that can confuse the server
|
|
|
|
|
$RM -f $MASTER_MYDDIR/log.*
|
|
|
|
|
# Remove stale binary logs
|
|
|
|
|
$RM -f $MYSQL_TEST_DIR/var/log/master-bin.*
|
|
|
|
|
|
|
|
|
|
CUR_MYERR=$MASTER_MYERR
|
|
|
|
|
CUR_MYSOCK=$MASTER_MYSOCK
|
|
|
|
|
#run master initialization shell script if one exists
|
|
|
|
|
|
|
|
|
|
if [ x$DO_DDD = x1 ]
|
|
|
|
|
then
|
|
|
|
|
$ECHO "set args $master_args" > $GDB_MASTER_INIT
|
|
|
|
|
manager_launch master ddd -display $DISPLAY --debugger \
|
|
|
|
|
"gdb -x $GDB_MASTER_INIT" $MYSQLD
|
|
|
|
|
elif [ x$DO_GDB = x1 ]
|
|
|
|
|
then
|
|
|
|
|
( echo set args $master_args;
|
|
|
|
|
if [ $USE_MANAGER = 0 ] ; then
|
|
|
|
|
cat <<EOF
|
|
|
|
|
if [ -f "$master_init_script" ] ;
|
|
|
|
|
then
|
|
|
|
|
/bin/sh $master_init_script
|
|
|
|
|
fi
|
|
|
|
|
cd $BASEDIR # for gcov
|
|
|
|
|
#start master
|
|
|
|
|
if [ -z "$DO_BENCH" ]
|
|
|
|
|
then
|
|
|
|
|
master_args="--no-defaults --log-bin=$MYSQL_TEST_DIR/var/log/master-bin \
|
|
|
|
|
--server-id=1 --rpl-recovery-rank=1 \
|
|
|
|
|
--basedir=$MY_BASEDIR --init-rpl-role=master \
|
|
|
|
|
--port=$MASTER_MYPORT \
|
|
|
|
|
--exit-info=256 \
|
|
|
|
|
--core \
|
|
|
|
|
--datadir=$MASTER_MYDDIR \
|
|
|
|
|
--pid-file=$MASTER_MYPID \
|
|
|
|
|
--socket=$MASTER_MYSOCK \
|
|
|
|
|
--log=$MASTER_MYLOG \
|
|
|
|
|
--character-sets-dir=$CHARSETSDIR \
|
|
|
|
|
--default-character-set=$CHARACTER_SET \
|
|
|
|
|
--tmpdir=$MYSQL_TMP_DIR \
|
|
|
|
|
--language=$LANGUAGE \
|
|
|
|
|
--innodb_data_file_path=ibdata1:50M \
|
|
|
|
|
$SMALL_SERVER \
|
|
|
|
|
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT"
|
|
|
|
|
else
|
|
|
|
|
master_args="--no-defaults --log-bin=$MYSQL_TEST_DIR/var/log/master-bin \
|
|
|
|
|
--server-id=1 --rpl-recovery-rank=1 \
|
|
|
|
|
--basedir=$MY_BASEDIR --init-rpl-role=master \
|
|
|
|
|
--port=$MASTER_MYPORT \
|
|
|
|
|
--datadir=$MASTER_MYDDIR \
|
|
|
|
|
--pid-file=$MASTER_MYPID \
|
|
|
|
|
--socket=$MASTER_MYSOCK \
|
|
|
|
|
--character-sets-dir=$CHARSETSDIR \
|
|
|
|
|
--default-character-set=$CHARACTER_SET \
|
|
|
|
|
--core \
|
|
|
|
|
--tmpdir=$MYSQL_TMP_DIR \
|
|
|
|
|
--language=$LANGUAGE \
|
|
|
|
|
--innodb_data_file_path=ibdata1:50M \
|
|
|
|
|
$SMALL_SERVER \
|
|
|
|
|
$EXTRA_MASTER_OPT $EXTRA_MASTER_MYSQLD_OPT"
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
CUR_MYERR=$MASTER_MYERR
|
|
|
|
|
CUR_MYSOCK=$MASTER_MYSOCK
|
|
|
|
|
|
|
|
|
|
if [ x$DO_DDD = x1 ]
|
|
|
|
|
then
|
|
|
|
|
$ECHO "set args $master_args" > $GDB_MASTER_INIT
|
|
|
|
|
manager_launch master ddd -display $DISPLAY --debugger \
|
|
|
|
|
"gdb -x $GDB_MASTER_INIT" $MYSQLD
|
|
|
|
|
elif [ x$DO_GDB = x1 ]
|
|
|
|
|
then
|
|
|
|
|
( echo set args $master_args;
|
|
|
|
|
if [ $USE_MANAGER = 0 ] ; then
|
|
|
|
|
cat <<EOF
|
|
|
|
|
b mysql_parse
|
|
|
|
|
commands 1
|
|
|
|
|
disa 1
|
|
|
|
|
end
|
|
|
|
|
r
|
|
|
|
|
EOF
|
|
|
|
|
fi ) > $GDB_MASTER_INIT
|
|
|
|
|
manager_launch master $XTERM -display $DISPLAY \
|
|
|
|
|
-title "Master" -e gdb -x $GDB_MASTER_INIT $MYSQLD
|
|
|
|
|
else
|
|
|
|
|
manager_launch master $MYSQLD $master_args
|
|
|
|
|
fi
|
|
|
|
|
fi ) > $GDB_MASTER_INIT
|
|
|
|
|
manager_launch master $XTERM -display $DISPLAY \
|
|
|
|
|
-title "Master" -e gdb -x $GDB_MASTER_INIT $MYSQLD
|
|
|
|
|
else
|
|
|
|
|
manager_launch master $MYSQLD $master_args
|
|
|
|
|
fi
|
|
|
|
|
sleep_until_file_exists $MASTER_MYPID
|
|
|
|
|
MASTER_RUNNING=1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
start_slave()
|
|
|
|
|
{
|
|
|
|
|
[ x$SKIP_SLAVE = x1 ] && return
|
|
|
|
|
eval "this_slave_running=\$SLAVE$1_RUNNING"
|
|
|
|
|
[ x$this_slave_running = 1 ] && return
|
|
|
|
|
#when testing fail-safe replication, we will have more than one slave
|
|
|
|
|
#in this case, we start secondary slaves with an argument
|
|
|
|
|
slave_ident="slave$1"
|
|
|
|
|
if [ -n "$1" ] ;
|
|
|
|
|
then
|
|
|
|
|
slave_server_id=`$EXPR 2 + $1`
|
|
|
|
|
slave_rpl_rank=$slave_server_id
|
|
|
|
|
slave_port=`expr $SLAVE_MYPORT + $1`
|
|
|
|
|
slave_log="$SLAVE_MYLOG.$1"
|
|
|
|
|
slave_err="$SLAVE_MYERR.$1"
|
|
|
|
|
slave_datadir="var/$slave_ident-data/"
|
|
|
|
|
slave_pid="$MYRUN_DIR/mysqld-$slave_ident.pid"
|
|
|
|
|
slave_sock="$SLAVE_MYSOCK-$1"
|
|
|
|
|
else
|
|
|
|
|
slave_server_id=2
|
|
|
|
|
slave_rpl_rank=2
|
|
|
|
|
slave_port=$SLAVE_MYPORT
|
|
|
|
|
slave_log=$SLAVE_MYLOG
|
|
|
|
|
slave_err=$SLAVE_MYERR
|
|
|
|
|
slave_datadir=$SLAVE_MYDDIR
|
|
|
|
|
slave_pid=$SLAVE_MYPID
|
|
|
|
|
slave_sock="$SLAVE_MYSOCK"
|
|
|
|
|
fi
|
|
|
|
|
# Remove stale binary logs
|
|
|
|
|
$RM -f $MYSQL_TEST_DIR/var/log/$slave_ident-bin.*
|
|
|
|
|
[ x$SKIP_SLAVE = x1 ] && return
|
|
|
|
|
eval "this_slave_running=\$SLAVE$1_RUNNING"
|
|
|
|
|
[ x$this_slave_running = 1 ] && return
|
|
|
|
|
#when testing fail-safe replication, we will have more than one slave
|
|
|
|
|
#in this case, we start secondary slaves with an argument
|
|
|
|
|
slave_ident="slave$1"
|
|
|
|
|
if [ -n "$1" ] ;
|
|
|
|
|
then
|
|
|
|
|
slave_server_id=`$EXPR 2 + $1`
|
|
|
|
|
slave_rpl_rank=$slave_server_id
|
|
|
|
|
slave_port=`expr $SLAVE_MYPORT + $1`
|
|
|
|
|
slave_log="$SLAVE_MYLOG.$1"
|
|
|
|
|
slave_err="$SLAVE_MYERR.$1"
|
|
|
|
|
slave_datadir="var/$slave_ident-data/"
|
|
|
|
|
slave_pid="$MYRUN_DIR/mysqld-$slave_ident.pid"
|
|
|
|
|
slave_sock="$SLAVE_MYSOCK-$1"
|
|
|
|
|
else
|
|
|
|
|
slave_server_id=2
|
|
|
|
|
slave_rpl_rank=2
|
|
|
|
|
slave_port=$SLAVE_MYPORT
|
|
|
|
|
slave_log=$SLAVE_MYLOG
|
|
|
|
|
slave_err=$SLAVE_MYERR
|
|
|
|
|
slave_datadir=$SLAVE_MYDDIR
|
|
|
|
|
slave_pid=$SLAVE_MYPID
|
|
|
|
|
slave_sock="$SLAVE_MYSOCK"
|
|
|
|
|
fi
|
|
|
|
|
# Remove stale binary logs
|
|
|
|
|
$RM -f $MYSQL_TEST_DIR/var/log/$slave_ident-bin.*
|
|
|
|
|
|
|
|
|
|
#run slave initialization shell script if one exists
|
|
|
|
|
if [ -f "$slave_init_script" ] ;
|
|
|
|
|
then
|
|
|
|
|
/bin/sh $slave_init_script
|
|
|
|
|
fi
|
|
|
|
|
#run slave initialization shell script if one exists
|
|
|
|
|
if [ -f "$slave_init_script" ] ;
|
|
|
|
|
then
|
|
|
|
|
/bin/sh $slave_init_script
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [ -z "$SLAVE_MASTER_INFO" ] ; then
|
|
|
|
|
master_info="--master-user=root \
|
|
|
|
|
--master-connect-retry=1 \
|
|
|
|
|
--master-host=127.0.0.1 \
|
|
|
|
|
--master-password= \
|
|
|
|
|
--master-port=$MASTER_MYPORT \
|
|
|
|
|
--server-id=$slave_server_id --rpl-recovery-rank=$slave_rpl_rank"
|
|
|
|
|
else
|
|
|
|
|
master_info=$SLAVE_MASTER_INFO
|
|
|
|
|
fi
|
|
|
|
|
if [ -z "$SLAVE_MASTER_INFO" ] ; then
|
|
|
|
|
master_info="--master-user=root \
|
|
|
|
|
--master-connect-retry=1 \
|
|
|
|
|
--master-host=127.0.0.1 \
|
|
|
|
|
--master-password= \
|
|
|
|
|
--master-port=$MASTER_MYPORT \
|
|
|
|
|
--server-id=$slave_server_id --rpl-recovery-rank=$slave_rpl_rank"
|
|
|
|
|
else
|
|
|
|
|
master_info=$SLAVE_MASTER_INFO
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
$RM -f $slave_datadir/log.*
|
|
|
|
|
slave_args="--no-defaults $master_info \
|
|
|
|
|
--exit-info=256 \
|
|
|
|
|
--log-bin=$MYSQL_TEST_DIR/var/log/$slave_ident-bin \
|
|
|
|
|
--log-slave-updates \
|
|
|
|
|
--log=$slave_log \
|
|
|
|
|
--basedir=$MY_BASEDIR \
|
|
|
|
|
--datadir=$slave_datadir \
|
|
|
|
|
--pid-file=$slave_pid \
|
|
|
|
|
--port=$slave_port \
|
|
|
|
|
--socket=$slave_sock \
|
|
|
|
|
--character-sets-dir=$CHARSETSDIR \
|
|
|
|
|
--default-character-set=$CHARACTER_SET \
|
|
|
|
|
--core --init-rpl-role=slave \
|
|
|
|
|
--tmpdir=$MYSQL_TMP_DIR \
|
|
|
|
|
--language=$LANGUAGE \
|
|
|
|
|
--skip-innodb --skip-slave-start \
|
|
|
|
|
--slave-load-tmpdir=$SLAVE_LOAD_TMPDIR \
|
|
|
|
|
--report-host=127.0.0.1 --report-user=root \
|
|
|
|
|
--report-port=$slave_port \
|
|
|
|
|
--master-retry-count=5 \
|
|
|
|
|
$SMALL_SERVER \
|
|
|
|
|
$EXTRA_SLAVE_OPT $EXTRA_SLAVE_MYSQLD_OPT"
|
|
|
|
|
CUR_MYERR=$slave_err
|
|
|
|
|
CUR_MYSOCK=$slave_sock
|
|
|
|
|
$RM -f $slave_datadir/log.*
|
|
|
|
|
slave_args="--no-defaults $master_info \
|
|
|
|
|
--exit-info=256 \
|
|
|
|
|
--log-bin=$MYSQL_TEST_DIR/var/log/$slave_ident-bin \
|
|
|
|
|
--log-slave-updates \
|
|
|
|
|
--log=$slave_log \
|
|
|
|
|
--basedir=$MY_BASEDIR \
|
|
|
|
|
--datadir=$slave_datadir \
|
|
|
|
|
--pid-file=$slave_pid \
|
|
|
|
|
--port=$slave_port \
|
|
|
|
|
--socket=$slave_sock \
|
|
|
|
|
--character-sets-dir=$CHARSETSDIR \
|
|
|
|
|
--default-character-set=$CHARACTER_SET \
|
|
|
|
|
--core --init-rpl-role=slave \
|
|
|
|
|
--tmpdir=$MYSQL_TMP_DIR \
|
|
|
|
|
--language=$LANGUAGE \
|
|
|
|
|
--skip-innodb --skip-slave-start \
|
|
|
|
|
--slave-load-tmpdir=$SLAVE_LOAD_TMPDIR \
|
|
|
|
|
--report-host=127.0.0.1 --report-user=root \
|
|
|
|
|
--report-port=$slave_port \
|
|
|
|
|
--master-retry-count=5 \
|
|
|
|
|
$SMALL_SERVER \
|
|
|
|
|
$EXTRA_SLAVE_OPT $EXTRA_SLAVE_MYSQLD_OPT"
|
|
|
|
|
CUR_MYERR=$slave_err
|
|
|
|
|
CUR_MYSOCK=$slave_sock
|
|
|
|
|
|
|
|
|
|
if [ x$DO_DDD = x1 ]
|
|
|
|
|
then
|
|
|
|
|
$ECHO "set args $master_args" > $GDB_SLAVE_INIT
|
|
|
|
|
manager_launch $slave_ident ddd -display $DISPLAY --debugger \
|
|
|
|
|
"gdb -x $GDB_SLAVE_INIT" $SLAVE_MYSQLD
|
|
|
|
|
elif [ x$DO_GDB = x1 ]
|
|
|
|
|
then
|
|
|
|
|
$ECHO "set args $slave_args" > $GDB_SLAVE_INIT
|
|
|
|
|
manager_launch $slave_ident $XTERM -display $DISPLAY -title "Slave" -e \
|
|
|
|
|
gdb -x $GDB_SLAVE_INIT $SLAVE_MYSQLD
|
|
|
|
|
else
|
|
|
|
|
manager_launch $slave_ident $SLAVE_MYSQLD $slave_args
|
|
|
|
|
fi
|
|
|
|
|
eval "SLAVE$1_RUNNING=1"
|
|
|
|
|
if [ x$DO_DDD = x1 ]
|
|
|
|
|
then
|
|
|
|
|
$ECHO "set args $master_args" > $GDB_SLAVE_INIT
|
|
|
|
|
manager_launch $slave_ident ddd -display $DISPLAY --debugger \
|
|
|
|
|
"gdb -x $GDB_SLAVE_INIT" $SLAVE_MYSQLD
|
|
|
|
|
elif [ x$DO_GDB = x1 ]
|
|
|
|
|
then
|
|
|
|
|
$ECHO "set args $slave_args" > $GDB_SLAVE_INIT
|
|
|
|
|
manager_launch $slave_ident $XTERM -display $DISPLAY -title "Slave" -e \
|
|
|
|
|
gdb -x $GDB_SLAVE_INIT $SLAVE_MYSQLD
|
|
|
|
|
else
|
|
|
|
|
manager_launch $slave_ident $SLAVE_MYSQLD $slave_args
|
|
|
|
|
fi
|
|
|
|
|
eval "SLAVE$1_RUNNING=1"
|
|
|
|
|
sleep_until_file_exists $slave_pid
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mysql_start () {
|
|
|
|
|
$ECHO "Starting MySQL daemon"
|
|
|
|
|
start_master
|
|
|
|
|
start_slave
|
|
|
|
|
cd $MYSQL_TEST_DIR
|
|
|
|
|
return 1
|
|
|
|
|
mysql_start ()
|
|
|
|
|
{
|
|
|
|
|
$ECHO "Starting MySQL daemon"
|
|
|
|
|
start_master
|
|
|
|
|
start_slave
|
|
|
|
|
cd $MYSQL_TEST_DIR
|
|
|
|
|
return 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
stop_slave ()
|
|
|
|
@ -840,8 +876,8 @@ stop_slave ()
|
|
|
|
|
then # try harder!
|
|
|
|
|
$ECHO "slave not cooperating with mysqladmin, will try manual kill"
|
|
|
|
|
kill `$CAT $slave_pid`
|
|
|
|
|
sleep $SLEEP_TIME
|
|
|
|
|
if [ -f $SLAVE_MYPID ] ; then
|
|
|
|
|
sleep_until_file_deleted $slave_pid
|
|
|
|
|
if [ -f $slave_pid ] ; then
|
|
|
|
|
$ECHO "slave refused to die. Sending SIGKILL"
|
|
|
|
|
kill -9 `$CAT $slave_pid`
|
|
|
|
|
$RM -f $slave_pid
|
|
|
|
@ -862,7 +898,7 @@ stop_master ()
|
|
|
|
|
then # try harder!
|
|
|
|
|
$ECHO "master not cooperating with mysqladmin, will try manual kill"
|
|
|
|
|
kill `$CAT $MASTER_MYPID`
|
|
|
|
|
sleep $SLEEP_TIME
|
|
|
|
|
sleep_until_file_deleted $MASTER_MYPID
|
|
|
|
|
if [ -f $MASTER_MYPID ] ; then
|
|
|
|
|
$ECHO "master refused to die. Sending SIGKILL"
|
|
|
|
|
kill -9 `$CAT $MASTER_MYPID`
|
|
|
|
@ -890,12 +926,11 @@ mysql_stop ()
|
|
|
|
|
return 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mysql_restart () {
|
|
|
|
|
|
|
|
|
|
mysql_stop
|
|
|
|
|
mysql_start
|
|
|
|
|
|
|
|
|
|
return 1
|
|
|
|
|
mysql_restart ()
|
|
|
|
|
{
|
|
|
|
|
mysql_stop
|
|
|
|
|
mysql_start
|
|
|
|
|
return 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mysql_loadstd () {
|
|
|
|
@ -1073,7 +1108,6 @@ run_testcase ()
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
######################################################################
|
|
|
|
|
# Main script starts here
|
|
|
|
|
######################################################################
|
|
|
|
@ -1083,16 +1117,38 @@ run_testcase ()
|
|
|
|
|
[ "$DO_GCOV" ] && gcov_prepare
|
|
|
|
|
[ "$DO_GPROF" ] && gprof_prepare
|
|
|
|
|
|
|
|
|
|
# Ensure that no old mysqld test servers are running
|
|
|
|
|
if [ -z "$USE_RUNNING_SERVER" ]
|
|
|
|
|
then
|
|
|
|
|
# Ensure that no old mysqld test servers are running
|
|
|
|
|
$MYSQLADMIN --no-defaults --socket=$MASTER_MYSOCK -u root -O connect_timeout=5 -O shutdown_timeout=20 shutdown > /dev/null 2>&1
|
|
|
|
|
$MYSQLADMIN --no-defaults --socket=$SLAVE_MYSOCK -u root -O connect_timeout=5 -O shutdown_timeout=20 shutdown > /dev/null 2>&1
|
|
|
|
|
$MYSQLADMIN --no-defaults --host=$hostname --port=$MASTER_MYPORT -u root -O connect_timeout=5 -O shutdown_timeout=20 shutdown > /dev/null 2>&1
|
|
|
|
|
$MYSQLADMIN --no-defaults --host=$hostname --port=$SLAVE_MYPORT -u root -O connect_timeout=5 -O shutdown_timeout=20 shutdown > /dev/null 2>&1
|
|
|
|
|
$MYSQLADMIN --no-defaults --host=$hostname --port=`expr $SLAVE_MYPORT + 1` -u root -O connect_timeout=5 -O shutdown_timeout=20 shutdown > /dev/null 2>&1
|
|
|
|
|
sleep_until_file_deleted $MASTER_MYPID
|
|
|
|
|
sleep_until_file_deleted $SLAVE_MYPID
|
|
|
|
|
|
|
|
|
|
# Kill any running managers
|
|
|
|
|
if [ -f "$MANAGER_PID_FILE" ]
|
|
|
|
|
then
|
|
|
|
|
kill `cat $MANAGER_PID_FILE`
|
|
|
|
|
sleep 1
|
|
|
|
|
if [ -f "$MANAGER_PID_FILE" ]
|
|
|
|
|
then
|
|
|
|
|
kill -9 `cat $MANAGER_PID_FILE`
|
|
|
|
|
sleep 1
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
# Remove files that can cause problems
|
|
|
|
|
$RM -f $MYSQL_TEST_DIR/var/run/* $MYSQL_TEST_DIR/var/tmp/*
|
|
|
|
|
|
|
|
|
|
$ECHO "Installing Test Databases"
|
|
|
|
|
mysql_install_db
|
|
|
|
|
start_manager
|
|
|
|
|
#do not automagically start deamons if we are in gdb or running only one test
|
|
|
|
|
#case
|
|
|
|
|
|
|
|
|
|
# Do not automagically start deamons if we are in gdb or running only one test
|
|
|
|
|
# case
|
|
|
|
|
if [ -z "$DO_GDB" ] && [ -z "$DO_DDD" ]
|
|
|
|
|
then
|
|
|
|
|
mysql_start
|
|
|
|
@ -1110,24 +1166,24 @@ $ECHO "Starting Tests"
|
|
|
|
|
|
|
|
|
|
if [ "$DO_BENCH" = 1 ]
|
|
|
|
|
then
|
|
|
|
|
BENCHDIR=$BASEDIR/sql-bench/
|
|
|
|
|
savedir=`pwd`
|
|
|
|
|
cd $BENCHDIR
|
|
|
|
|
if [ -z "$1" ]
|
|
|
|
|
then
|
|
|
|
|
./run-all-tests --socket=$MASTER_MYSOCK --user=root
|
|
|
|
|
else
|
|
|
|
|
if [ -x "./$1" ]
|
|
|
|
|
BENCHDIR=$BASEDIR/sql-bench/
|
|
|
|
|
savedir=`pwd`
|
|
|
|
|
cd $BENCHDIR
|
|
|
|
|
if [ -z "$1" ]
|
|
|
|
|
then
|
|
|
|
|
./$1 --socket=$MASTER_MYSOCK --user=root
|
|
|
|
|
./run-all-tests --socket=$MASTER_MYSOCK --user=root
|
|
|
|
|
else
|
|
|
|
|
echo "benchmark $1 not found"
|
|
|
|
|
if [ -x "./$1" ]
|
|
|
|
|
then
|
|
|
|
|
./$1 --socket=$MASTER_MYSOCK --user=root
|
|
|
|
|
else
|
|
|
|
|
echo "benchmark $1 not found"
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
cd $savedir
|
|
|
|
|
mysql_stop
|
|
|
|
|
stop_manager
|
|
|
|
|
exit
|
|
|
|
|
cd $savedir
|
|
|
|
|
mysql_stop
|
|
|
|
|
stop_manager
|
|
|
|
|
exit
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
$ECHO
|
|
|
|
|