You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

192 lines
5.1 KiB

Changed safe_mysqld -> mysqld_safe Added some alias to SHOW commands Prepare for dynamic changing of MySQL variables man/Makefile.am: Changed safe_mysqld -> mysqld_safe man/isamchk.1: Changed safe_mysqld -> mysqld_safe man/isamlog.1: Changed safe_mysqld -> mysqld_safe man/mysql.1: Changed safe_mysqld -> mysqld_safe man/mysql_zap.1: Changed safe_mysqld -> mysqld_safe man/mysqlaccess.1: Changed safe_mysqld -> mysqld_safe man/mysqladmin.1: Changed safe_mysqld -> mysqld_safe man/mysqld.1: Changed safe_mysqld -> mysqld_safe man/mysqld_multi.1: Changed safe_mysqld -> mysqld_safe man/mysqld_safe.1: Changed safe_mysqld -> mysqld_safe man/mysqldump.1: Changed safe_mysqld -> mysqld_safe man/mysqlshow.1: Changed safe_mysqld -> mysqld_safe man/perror.1: Changed safe_mysqld -> mysqld_safe man/replace.1: Changed safe_mysqld -> mysqld_safe man/which.2: Changed safe_mysqld -> mysqld_safe myisam/mi_search.c: Fixed bug when using packed keys. scripts/Makefile.am: Changed safe_mysqld -> mysqld_safe scripts/make_binary_distribution.sh: Changed safe_mysqld -> mysqld_safe scripts/mysql_install_db.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_multi.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_safe-watch.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_safe.sh: Changed safe_mysqld -> mysqld_safe sql/lex.h: Addex SHOW INDEXES as an alias for SHOW INDEX sql/sql_class.cc: Prepare for dynamic changing of MySQL variables sql/sql_lex.h: Prepare for dynamic changing of MySQL variables sql/sql_yacc.yy: Some changes to SHOW commands. support-files/binary-configure.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql-max.spec.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql-multi.server.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql.server.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql.spec.sh: Changed safe_mysqld -> mysqld_safe
25 years ago
Changed safe_mysqld -> mysqld_safe Added some alias to SHOW commands Prepare for dynamic changing of MySQL variables man/Makefile.am: Changed safe_mysqld -> mysqld_safe man/isamchk.1: Changed safe_mysqld -> mysqld_safe man/isamlog.1: Changed safe_mysqld -> mysqld_safe man/mysql.1: Changed safe_mysqld -> mysqld_safe man/mysql_zap.1: Changed safe_mysqld -> mysqld_safe man/mysqlaccess.1: Changed safe_mysqld -> mysqld_safe man/mysqladmin.1: Changed safe_mysqld -> mysqld_safe man/mysqld.1: Changed safe_mysqld -> mysqld_safe man/mysqld_multi.1: Changed safe_mysqld -> mysqld_safe man/mysqld_safe.1: Changed safe_mysqld -> mysqld_safe man/mysqldump.1: Changed safe_mysqld -> mysqld_safe man/mysqlshow.1: Changed safe_mysqld -> mysqld_safe man/perror.1: Changed safe_mysqld -> mysqld_safe man/replace.1: Changed safe_mysqld -> mysqld_safe man/which.2: Changed safe_mysqld -> mysqld_safe myisam/mi_search.c: Fixed bug when using packed keys. scripts/Makefile.am: Changed safe_mysqld -> mysqld_safe scripts/make_binary_distribution.sh: Changed safe_mysqld -> mysqld_safe scripts/mysql_install_db.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_multi.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_safe-watch.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_safe.sh: Changed safe_mysqld -> mysqld_safe sql/lex.h: Addex SHOW INDEXES as an alias for SHOW INDEX sql/sql_class.cc: Prepare for dynamic changing of MySQL variables sql/sql_lex.h: Prepare for dynamic changing of MySQL variables sql/sql_yacc.yy: Some changes to SHOW commands. support-files/binary-configure.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql-max.spec.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql-multi.server.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql.server.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql.spec.sh: Changed safe_mysqld -> mysqld_safe
25 years ago
Changed safe_mysqld -> mysqld_safe Added some alias to SHOW commands Prepare for dynamic changing of MySQL variables man/Makefile.am: Changed safe_mysqld -> mysqld_safe man/isamchk.1: Changed safe_mysqld -> mysqld_safe man/isamlog.1: Changed safe_mysqld -> mysqld_safe man/mysql.1: Changed safe_mysqld -> mysqld_safe man/mysql_zap.1: Changed safe_mysqld -> mysqld_safe man/mysqlaccess.1: Changed safe_mysqld -> mysqld_safe man/mysqladmin.1: Changed safe_mysqld -> mysqld_safe man/mysqld.1: Changed safe_mysqld -> mysqld_safe man/mysqld_multi.1: Changed safe_mysqld -> mysqld_safe man/mysqld_safe.1: Changed safe_mysqld -> mysqld_safe man/mysqldump.1: Changed safe_mysqld -> mysqld_safe man/mysqlshow.1: Changed safe_mysqld -> mysqld_safe man/perror.1: Changed safe_mysqld -> mysqld_safe man/replace.1: Changed safe_mysqld -> mysqld_safe man/which.2: Changed safe_mysqld -> mysqld_safe myisam/mi_search.c: Fixed bug when using packed keys. scripts/Makefile.am: Changed safe_mysqld -> mysqld_safe scripts/make_binary_distribution.sh: Changed safe_mysqld -> mysqld_safe scripts/mysql_install_db.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_multi.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_safe-watch.sh: Changed safe_mysqld -> mysqld_safe scripts/mysqld_safe.sh: Changed safe_mysqld -> mysqld_safe sql/lex.h: Addex SHOW INDEXES as an alias for SHOW INDEX sql/sql_class.cc: Prepare for dynamic changing of MySQL variables sql/sql_lex.h: Prepare for dynamic changing of MySQL variables sql/sql_yacc.yy: Some changes to SHOW commands. support-files/binary-configure.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql-max.spec.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql-multi.server.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql.server.sh: Changed safe_mysqld -> mysqld_safe support-files/mysql.spec.sh: Changed safe_mysqld -> mysqld_safe
25 years ago
  1. #!/bin/sh
  2. # Copyright Abandoned 1996 TCX DataKonsult AB & Monty Program KB & Detron HB
  3. # This file is public domain and comes with NO WARRANTY of any kind
  4. # Mysql daemon start/stop script. Multi-instance enhancements by Tim Bunce.
  5. # Usually this is put in /etc/init.d (at least on machines SYSV R4
  6. # based systems) and linked to
  7. # /etc/rc3.d/S99mysql.svr1
  8. # and /etc/rc0.d/S01mysql.svr1
  9. # When this is done the mysql server will be started when the machine is
  10. # started and shut down when the systems goes down. The '.svr1' suffix can
  11. # be used to identify one of a number of servers. Multiple symlinks can be
  12. # created, one per instance. The 'svrN' suffix can then be used to
  13. # prefix configuration variables in a seperate section of /etc/my.cnf.
  14. # See example below.
  15. #
  16. # A typical multi-instance /etc/my.cnf file would look like:
  17. # [mysqld]
  18. # basedir=...
  19. # set-variable = key_buffer_size=16M
  20. # set-variable = max_allowed_packet=1M
  21. # [mysql_multi_server]
  22. # svr1-datadir=/foo1/bar
  23. # svr2-datadir=/foo2/bar
  24. #
  25. # and then the /foo1/bar/my.cnf and /foo2/bar/my.cnf files
  26. # would contain all the *instance specific* configurations.
  27. #
  28. # This script can also be run manually in which case the server instance
  29. # is identified by an extra argument, for example:
  30. # /etc/init.d/mysql stop svr3
  31. #
  32. PATH=/sbin:/usr/sbin:/bin:/usr/bin
  33. export PATH
  34. mode=$1 # start or stop
  35. svr=$2 # eg 'svr1' (optional)
  36. if [ "$2" = "" ]
  37. then name=`basename $0`
  38. else name=$2
  39. fi
  40. # Extract identity of the server we are working with
  41. svr=`echo "$name" | sed -e 's/.*\<\(svr[1-9][0-9]*\)\>.*/\1/'`
  42. if [ "$svr" = "" ]
  43. then
  44. echo "Can't determine database svr number from name '$name'"
  45. exit 1
  46. fi
  47. echo "mysqld $svr $mode"
  48. parse_arguments() {
  49. for arg do
  50. case "$arg" in
  51. --basedir=*|--${svr}-basedir=*)
  52. basedir=`echo "$arg" | sed -e 's/^[^=]*=//'` ;;
  53. --datadir=*|--${svr}-basedir=*)
  54. datadir=`echo "$arg" | sed -e 's/^[^=]*=//'` ;;
  55. --pid-file=*|--${svr}-basedir=*)
  56. pid_file=`echo "$arg" | sed -e 's/^[^=]*=//'` ;;
  57. esac
  58. done
  59. }
  60. # Get arguments from the my.cnf file, groups [mysqld], [mysql_server],
  61. # and mysql_multi_server
  62. if test -x ./bin/my_print_defaults
  63. then
  64. print_defaults="./bin/my_print_defaults"
  65. elif test -x @bindir@/my_print_defaults
  66. then
  67. print_defaults="@bindir@/my_print_defaults"
  68. elif test -x @bindir@/mysql_print_defaults
  69. then
  70. print_defaults="@bindir@/mysql_print_defaults"
  71. else
  72. # Try to find basedir in /etc/my.cnf
  73. conf=/etc/my.cnf
  74. print_defaults=
  75. if test -r $conf
  76. then
  77. subpat='^[^=]*basedir[^=]*=\(.*\)$'
  78. dirs=`sed -e "/$subpat/!d" -e 's//\1/' $conf
  79. for d in $dirs
  80. do
  81. d=`echo $d | sed -e 's/[ ]//g'`
  82. if test -x "$d/bin/my_print_defaults"
  83. then
  84. print_defaults="$d/bin/my_print_defaults"
  85. break
  86. fi
  87. if test -x "$d/bin/mysql_print_defaults"
  88. then
  89. print_defaults="$d/bin/mysql_print_defaults"
  90. break
  91. fi
  92. done
  93. fi
  94. # Hope it's in the PATH ... but I doubt it
  95. test -z "$print_defaults" && print_defaults="my_print_defaults"
  96. fi
  97. datadir=@localstatedir@
  98. basedir=
  99. pid_file=
  100. parse_arguments `$print_defaults $defaults mysqld mysql_server mysql_multi_server`
  101. if test -z "$basedir"
  102. then
  103. basedir=@prefix@
  104. bindir=@bindir@
  105. else
  106. bindir="$basedir/bin"
  107. fi
  108. if test -z "$pid_file"
  109. then
  110. pid_file=$datadir/`@HOSTNAME@`.pid
  111. else
  112. case "$pid_file" in
  113. /* ) ;;
  114. * ) pid_file="$datadir/$pid_file" ;;
  115. esac
  116. fi
  117. # Safeguard (relative paths, core dumps..)
  118. cd $basedir
  119. case "$mode" in
  120. 'start')
  121. # Start daemon
  122. if test -x $bindir/mysqld_safe
  123. then
  124. # We only need to specify datadir and pid-file here and we
  125. # get all other instance-specific config from $datadir/my.cnf.
  126. # We have to explicitly pass --defaults-extra-file because it
  127. # reads the config files before the command line options.
  128. # Also it must be first because of the way mysqld_safe works.
  129. $bindir/mysqld_safe --defaults-extra-file=$datadir/my.cnf \
  130. --datadir=$datadir --pid-file=$pid_file &
  131. # Make lock for RedHat / SuSE
  132. if test -d /var/lock/subsys
  133. then
  134. touch /var/lock/subsys/mysql
  135. fi
  136. else
  137. echo "Can't execute $bindir/mysqld_safe"
  138. fi
  139. ;;
  140. 'stop')
  141. # Stop daemon. We use a signal here to avoid having to know the
  142. # root password.
  143. if test -f "$pid_file"
  144. then
  145. mysqld_pid=`cat $pid_file`
  146. echo "Killing mysqld $svr with pid $mysqld_pid"
  147. kill $mysqld_pid
  148. # mysqld should remove the pid_file when it exits, so wait for it.
  149. sleep 1
  150. while [ -s $pid_file -a "$flags" != aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa ]
  151. do
  152. [ -z "$flags" ] && echo "Wait for mysqld $svr to exit\c" || echo ".\c"
  153. flags=a$flags
  154. sleep 1
  155. done
  156. if [ -s $pid_file ]
  157. then echo " gave up waiting!"
  158. elif [ -n "$flags" ]
  159. then echo " done"
  160. fi
  161. # delete lock for RedHat / SuSE
  162. if test -e /var/lock/subsys/mysql
  163. then
  164. rm /var/lock/subsys/mysql
  165. fi
  166. else
  167. echo "No mysqld pid file found. Looked for $pid_file."
  168. fi
  169. ;;
  170. *)
  171. # usage
  172. echo "usage: $0 start|stop [ svrN ]"
  173. exit 1
  174. ;;
  175. esac