|
|
- #!/bin/sh /etc/rc.common
- # Copyright (C) 2010-2018 OpenWrt.org
-
- START=95
- STOP=10
-
- NAME=mysqld
-
- LOGGER="/usr/bin/logger -p user.err -s -t $NAME --"
-
- MYSQLADMIN=/usr/bin/mysqladmin
- MYSQLD=/usr/bin/$NAME
- MYSQLDSAFE=/usr/bin/mysqld_safe
-
- # mysqladmin likes to read /root/.my.cnf which could cause issues.
- export HOME=/etc/mysql
-
- # Safeguard (relative paths, core dumps...)
- cd /
-
- mysqld_get_param() {
- $MYSQLD --print-defaults \
- | tr " " "\n" \
- | grep -- "--$1" \
- | tail -n 1 \
- | cut -d= -f2
- }
-
- # Checks if a server is running and accessible.
- #
- # check_alive insists on a pingable server
- # check_dead also fails if there is a lost mysqld in the process list
- #
- # Usage: boolean mysqld_status [check_alive|check_dead]
- mysqld_status() {
- if $MYSQLADMIN ping >/dev/null 2>&1; then
- ping_alive=1
- else
- ping_alive=0
- fi
-
- ps_alive=0
- pidfile=$(mysqld_get_param pid-file)
- if [ -f "$pidfile" ] && kill -0 $(cat "$pidfile") >/dev/null 2>&1; then
- ps_alive=1
- fi
-
- if { [ "$1" = check_alive ] && [ $ping_alive = 1 ]; } || \
- { [ "$1" = check_dead ] && [ $ping_alive = 0 ] \
- && [ $ps_alive = 0 ]; }
- then
- return 0 # EXIT_SUCCESS
- else
- return 1 # EXIT_FAILURE
- fi
- }
-
- start() {
- conf=/etc/mysql/my.cnf
- logdir=/var/log/mysql
- rundir=/var/run/mysqld
-
- hint="please fix your server configuration in /etc/mysql/"
-
- for i in $MYSQLD $MYSQLADMIN $MYSQLDSAFE; do
- if [ ! -x $i ]; then
- $LOGGER $i is missing
- exit 1
- fi
- done
-
- if [ ! -r $conf ]; then
- $LOGGER $conf cannot be read
- exit 1
- fi
-
- config_load $NAME
-
- config_get_bool enabled general enabled 0
- if [ $enabled -eq 0 ]; then
- $LOGGER service not enabled in /etc/config/$NAME
- exit 1
- fi
-
- config_get options general options
-
- datadir=$(mysqld_get_param datadir)
- tmpdir=$(mysqld_get_param tmpdir)
-
- if [ -z "$datadir" ]; then
- $LOGGER datadir is not set
- $LOGGER $hint
- exit 1
- fi
-
- if [ -z "$tmpdir" ]; then
- $LOGGER tmpdir is not set
- $LOGGER $hint
- exit 1
- fi
-
- if [ ! -f "$datadir/mysql/tables_priv.MAD" ]; then
- args="--force"
- basedir=$(mysqld_get_param basedir)
- [ -n "$basedir" ] && args="$args --basedir=$basedir"
-
- $LOGGER Cannot detect privileges table. You might need to run
- $LOGGER \'mysql_install_db "$args"\'
- $LOGGER to initialize the system tables.
- exit 1
- fi
-
- # Start daemon
- if mysqld_status check_alive; then
- $LOGGER already running
- else
- for i in $logdir $rundir; do
- opts="-m 0750"
- if ! [ -e $i ]; then
- # $rundir needs to be accessible for
- # clients
- if [ $i = $rundir ]; then
- opts=
- fi
- mkdir -p $opts $i
- [ -d $i ] && chown mariadb:mariadb $i
- fi
- done
-
- $MYSQLDSAFE $options >/dev/null 2>&1 &
- fi
- }
-
- stop() {
- if ! mysqld_status check_dead; then
- $MYSQLADMIN shutdown
- fi
- }
-
- reload() {
- if mysqld_status check_alive; then
- $MYSQLADMIN reload
- else
- $LOGGER not running
- fi
- }
|