#!@RCD_SCRIPTS_SHELL@ # # $NetBSD: mysqld.sh,v 1.1.1.1 2010/03/04 16:28:58 taca Exp $ # # PROVIDE: mysqld # REQUIRE: DAEMON LOGIN mountall # KEYWORD: shutdown # # You will need to set some variables in /etc/rc.conf to start MySQL: # # mysqld=YES # # The following variables are optional: # # mysqld_user="mysql" # user to run mysqld as # mysqld_datadir="/path/to/home" # path to MySQL database directory # if [ -f /etc/rc.subr ]; then . /etc/rc.subr fi name="mysqld" rcvar=${name} command="@PREFIX@/bin/mysqld_safe" procname="@PREFIX@/libexec/${name}" : ${mysqld_user:=@MYSQL_USER@} : ${mysqld_group:=@MYSQL_GROUP@} : ${mysqld_datadir:=@MYSQL_DATADIR@} extra_commands="initdb" initdb_cmd="mysqld_initdb" start_precmd="mysqld_precmd" start_cmd="mysqld_start" # Don't drop thread priority unless on Linux or SunOS # ref. http://bugs.mysql.com/bug.php?id=18526 case $(uname -s) in Linux|SunOS) thread_flags="";; *) thread_flags="--skip-thread-priority" esac mysqld_precmd() { if [ ! -d ${mysqld_datadir}/mysql ]; then mysqld_initdb fi } mysqld_initdb() { initdb="@PREFIX@/bin/mysql_install_db" if [ ! -x ${initdb} ]; then return 1 fi if [ -f ${mysqld_datadir}/mysql/host.frm ]; then @ECHO@ "The MySQL database has already been initialized." @ECHO@ "Skipping database initialization." else @ECHO@ "Initializing MySQL database system tables." ${initdb} --force --user=${mysqld_user} \ --datadir=${mysqld_datadir} || return 1 if [ -d ${mysqld_datadir} ]; then @CHOWN@ -R ${mysqld_user}:${mysqld_group} \ ${mysqld_datadir} fi fi } mysqld_start() { for f in $required_files; do if [ ! -r "$f" ]; then @ECHO@ 1>&2 "$0: WARNING: $f is not readable" if [ -z $rc_force ]; then return 1 fi fi done @ECHO@ "Starting ${name}." ulimit -n 4096 cd @PREFIX@ ${command} --user=${mysqld_user} --datadir=${mysqld_datadir} \ --pid-file=${pidfile} ${mysqld_flags} \ ${thread_flags} & } if [ -f /etc/rc.subr -a -d /etc/rc.d -a -f /etc/rc.d/DAEMON ]; then load_rc_config $name pidfile="${mysqld_datadir}/`@HOSTNAME_CMD@`.pid" run_rc_command "$1" else if [ -f /etc/rc.conf ]; then . /etc/rc.conf fi pidfile="${mysqld_datadir}/`@HOSTNAME_CMD@`.pid" case "$1" in initdb) eval ${initdb_cmd} ;; stop) if [ -r "${pidfile}" ]; then @ECHO@ "Stopping ${name}." kill `@CAT@ ${pidfile}` fi ;; *) eval ${start_precmd} eval ${start_cmd} ;; esac fi