mirror of
https://github.com/MariaDB/server.git
synced 2025-01-28 17:54:16 +01:00
5a2419eb89
Docs/manual.texi: Change log + bug fixes from the mailing list configure.in: added mlockall include/config-win.h: Fix to use SAFE_MUTEX include/ft_global.h: Free memory include/my_pthread.h: Fix for SAFE_MUTEX on windows myisam/Makefile.am: Fix modes myisam/ft_static.c: Fix language problem with fulltext myisam/ft_stopwords.c: Free memory at end myisam/mi_create.c: Fix language problem with fulltext myisam/mi_delete.c: Added optimization to not join blocks when using delete with QUICK myisam/mi_panic.c: Added freeing of memorty myisam/mi_test2.c: Added quick mode myisam/myisamchk.c: Fixed help text myisam/myisamdef.h: Added optimization to not join blocks when using delete with QUICK mysys/mf_format.c: Don't change case for extension mysys/my_wincond.c: Fix for safe mutex mysys/thr_mutex.c: Fix for safe mutex sql-bench/test-insert.sh: Split delete test to get more information about the times sql/ChangeLog: Changelog sql/ha_myisam.cc: Better OPTIMIZE handling sql/log.cc: Cleanup sql/mysql_priv.h: Fix for safe mutex sql/mysqld.cc: Added define for --one-thread option sql/sql_class.h: Fixed lock_time in slow_log sql/sql_delete.cc: Fix for safe mutex sql/sql_parse.cc: Fix processlist message for new process sql/sql_table.cc: Fix windows problem med CREATE INDEX sql/sql_yacc.yy: Fix for safe mutex sql/table.cc: Made code simpler strings/bmove512.c: Small speed fix support-files/mysql.server.sh: Fixed awk usage
122 lines
3.3 KiB
Bash
122 lines
3.3 KiB
Bash
#!/bin/sh
|
|
# Copyright Abandoned 1996 TCX DataKonsult AB & Monty Program KB & Detron HB
|
|
# This file is public domain and comes with NO WARRANTY of any kind
|
|
|
|
# Mysql daemon start/stop script.
|
|
|
|
# Usually this is put in /etc/init.d (at least on machines SYSV R4
|
|
# based systems) and linked to /etc/rc3.d/S99mysql and /etc/rc0.d/S01mysql.
|
|
# When this is done the mysql server will be started when the machine is started
|
|
# and shut down when the systems goes down.
|
|
|
|
# Comments to support chkconfig on RedHat Linux
|
|
# chkconfig: 2345 90 90
|
|
# description: A very fast and reliable SQL database engine.
|
|
|
|
# The following variables are only set for letting mysql.server find things
|
|
# if you want to affect other MySQL variables, you should make your changes
|
|
# in the /etc/my.cnf or other configuration files
|
|
|
|
PATH=/sbin:/usr/sbin:/bin:/usr/bin
|
|
basedir=@prefix@
|
|
bindir=@bindir@
|
|
sbindir=@sbindir@
|
|
datadir=@localstatedir@
|
|
pid_file=@localstatedir@/mysqld.pid
|
|
|
|
export PATH
|
|
|
|
mode=$1
|
|
|
|
GetCNF () {
|
|
|
|
VARIABLES="basedir bindir sbindir datadir pid-file"
|
|
CONFIG_FILES="/etc/my.cnf $basedir/my.cnf $HOME/.my.cnf"
|
|
|
|
for c in $CONFIG_FILES
|
|
do
|
|
if [ -f $c ]
|
|
then
|
|
#echo "Processing $c..."
|
|
for v in $VARIABLES
|
|
do
|
|
# This method assumes last of duplicate $variable entries will be the
|
|
# value set ([mysqld])
|
|
# This could easily be rewritten to gather [xxxxx]-specific entries,
|
|
# but for now it looks like only the mysqld ones are needed for
|
|
# server startup scripts
|
|
thevar=""
|
|
eval `sed -n -e '/^$/d' -e '/^#/d' -e 's,[ ],,g' -e '/=/p' $c |\
|
|
awk -F= -v v=$v '{if ($1 == v) printf ("thevar=\"%s\"\n", $2)}'`
|
|
|
|
# it would be easier if the my.cnf and variable values were
|
|
# all matched, but since they aren't we need to map them here.
|
|
case $v in
|
|
pid-file) v=pid_file ;;
|
|
log) v=log_file ;;
|
|
esac
|
|
|
|
# As long as $thevar isn't blank, use it to set or override current
|
|
# value
|
|
[ "$thevar" != "" ] && eval $v=$thevar
|
|
|
|
done
|
|
#else
|
|
# echo "No $c config file."
|
|
fi
|
|
done
|
|
}
|
|
|
|
# run function to get config values
|
|
GetCNF
|
|
|
|
# Safeguard (relative paths, core dumps..)
|
|
cd $basedir
|
|
|
|
case "$mode" in
|
|
'start')
|
|
# Start daemon
|
|
|
|
if test -x $bindir/safe_mysqld
|
|
then
|
|
# Give extra arguments to mysqld with the my.cnf file. This script may
|
|
# be overwritten at next upgrade.
|
|
$bindir/safe_mysqld \
|
|
--datadir=$datadir --pid-file=$pid_file &
|
|
else
|
|
echo "Can't execute $bindir/safe_mysqld"
|
|
fi
|
|
;;
|
|
|
|
'stop')
|
|
# Stop daemon. We use a signal here to avoid having to know the
|
|
# root password.
|
|
if test -f "$pid_file"
|
|
then
|
|
mysqld_pid=`cat $pid_file`
|
|
echo "Killing mysqld with pid $mysqld_pid"
|
|
kill $mysqld_pid
|
|
# mysqld should remove the pid_file when it exits, so wait for it.
|
|
|
|
sleep 1
|
|
while [ -s $pid_file -a "$flags" != aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa ]
|
|
do [ -z "$flags" ] && echo "Wait for mysqld to exit\c" || echo ".\c"
|
|
flags=a$flags
|
|
sleep 1
|
|
done
|
|
if [ -s $pid_file ]
|
|
then echo " gave up waiting!"
|
|
elif [ -n "$flags" ]
|
|
then echo " done"
|
|
fi
|
|
else
|
|
echo "No mysqld pid file found. Looked for $pid_file."
|
|
fi
|
|
;;
|
|
|
|
*)
|
|
# usage
|
|
echo "usage: $0 start|stop"
|
|
exit 1
|
|
;;
|
|
esac
|