#!/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 }