|
|
- #!/bin/sh /etc/rc.common
- # Copyright (C) 2010-2018 OpenWrt.org
-
- # shellcheck disable=SC2034
- START=95
- # shellcheck disable=SC2034
- STOP=10
- # shellcheck disable=SC2034
- USE_PROCD=1
-
- NAME=mysqld
-
- LOGGER="/usr/bin/logger -p user.err -s -t $NAME --"
- [ -x "$LOGGER" ] || LOGGER="echo"
-
- MYSQLD="/usr/bin/$NAME"
-
- pidfile=""
-
- # 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" --help --verbose | sed -n 's|^'"$1"'[[:blank:]]\+||p'
- }
-
- # Send kill signal to MariaDB process
- #
- # Usage: boolean mysqld_kill signal
- mysql_kill() {
- [ -n "$pidfile" ] || pidfile="$(mysqld_get_param pid-file)"
- [ -f "$pidfile" ] || return 1
- pid="$(cat "$pidfile")"
- [ -n "$pid" ] || return 2
- kill "$1" "$pid"
- }
-
- # Checks if a server is running and accessible.
- #
- # Supported modes are 'check_alive' and 'check_dead'.
- # Both check for pidfile and whether the specified process is running and is
- # indeed mysqld. We could use mysqladmin for the check, but to be able to do
- # so, mysqladmin requires access to the database, which sounds like overkill
- # and potential security issue.
- #
- # Usage: boolean mysqld_status [check_alive|check_dead]
- mysqld_status() {
- ps_alive=0
- pidfile="$(mysqld_get_param pid-file)"
- if [ -f "$pidfile" ] && mysql_kill -0 2> /dev/null && \
- [ "$(readlink "/proc/$(cat "$pidfile")/exe")" = "$MYSQLD" ]; then
- ps_alive=1
- fi
-
- if { [ "$1" = check_alive ] && [ $ps_alive = 1 ]; } || \
- { [ "$1" = check_dead ] && [ $ps_alive = 0 ]; }
- then
- return 0 # EXIT_SUCCESS
- else
- return 1 # EXIT_FAILURE
- fi
- }
-
- start_service() {
- conf=/etc/mysql/my.cnf
- logdir=/var/log/mysql
- rundir=/var/run/mysqld
- version="$(mysqld --version | sed -n 's|.*Ver[[:blank:]]*\([0-9.]*\)-.*|\1|p')"
-
- # Few basic checks
- if [ ! -x "$MYSQLD" ]; then
- $LOGGER "$MYSQLD is missing"
- exit 1
- fi
-
- if [ -z "$version" ]; then
- $LOGGER "Can't get MariaDB version, something is seriously wrong"
- exit 1
- fi
-
- if [ ! -r "$conf" ]; then
- $LOGGER "$conf cannot be read"
- exit 1
- fi
-
- if mysqld_status check_alive; then
- $LOGGER "server is already running"
- exit 0
- fi
-
- # Get various config options
- config_load "$NAME"
- config_get my_user general user "mariadb"
- config_get my_group general group "mariadb"
- config_get_bool enabled general enabled 0
- config_get_bool init_db general init 1
- config_get_bool autoupgrade general upgrade 1
- config_get options general options
-
- # shellcheck disable=SC2154
- if [ "$enabled" -eq 0 ]; then
- $LOGGER "service not enabled in /etc/config/$NAME"
- exit 1
- fi
-
- datadir="$(mysqld_get_param datadir)"
- tmpdir="$(mysqld_get_param tmpdir)"
- sockdir="$(dirname "$(mysqld_get_param socket)")"
-
- # Make sure we have a working database in datadir
- if [ ! -f "$datadir/mysql/tables_priv.MAD" ]; then
- args="--force"
- basedir="$(mysqld_get_param basedir)"
- [ -n "$basedir" ] && args="$args --basedir=$basedir"
-
- # shellcheck disable=SC2154
- if [ "$init_db" -gt 0 ]; then
- # shellcheck disable=SC2154
- mysql_install_db $args --skip-name-resolve --skip-test-db --datadir="$datadir" || exit 1
- echo "$version" > "$datadir"/.version
- chown -Rh "$my_user:$my_group" "$datadir"
- else
- $LOGGER "Cannot detect privileges table. You might need to run"
- $LOGGER "'mysql_install_db \"$args\"'"
- $LOGGER "to initialize the system tables."
- $LOGGER "Then hand it ower to MariaDB user"
- # shellcheck disable=SC2154
- $LOGGER "'chown -Rh \"$my_user:$my_group\" \"$datadir\"'"
- exit 1
- fi
- fi
-
- # Make sure all required directories exists and have correct rights
- for i in "$logdir" "$rundir" "$sockdir"; do
- opts="-m 0750"
- if ! [ -e "$i" ]; then
- # $rundir needs to be accessible for
- # clients
- if [ "$i" = "$rundir" ]; then
- opts=
- fi
- # shellcheck disable=SC2086
- mkdir -p $opts "$i"
- fi
- # shellcheck disable=SC2154
- [ -d "$i" ] && chown -Rh "$my_user:$my_group" "$i"
- done
-
- # Migration from old versions
- # shellcheck disable=SC2154
- if [ "$(cat "$datadir"/.version 2> /dev/null)" \!= "$version" ] && [ "$autoupgrade" -gt 0 ]; then
- # Check for correct owner
- local owner="$(stat --format %U:%G "$datadir" 2> /dev/null)"
- if [ -n "$owner" ] && [ "$owner" != "$my_user:$my_group" ]; then
- chown -Rh "$my_user:$my_group" "$datadir"
- fi
-
- # Start upgrade instance without credentials
- sudo -u "$my_user" mysqld --skip-networking --skip-grant-tables --socket=/tmp/mysql_upgrade.sock &
- PID="$!"
- i=0
- # Wait for upgrade instance of db to start
- while [ "$i" -lt 15 ] && test \! -S /tmp/mysql_upgrade.sock; do
- sleep 1
- i="$((i + 1))"
- done
- [ -S /tmp/mysql_upgrade.sock ] || {
- $LOGGER "Failed to start upgrading instance of MariaDB."
- exit 1
- }
- # Upgrade the database
- mysql_upgrade --upgrade-system-tables --socket=/tmp/mysql_upgrade.sock
- echo "$version" > "$datadir"/.version
- # Stop the upgrade instance
- kill "$PID"
- i=0
- while [ "$i" -lt 60 ] && grep -q mysql "/proc/$PID/cmdline"; do
- sleep 1
- [ "$i" -lt 30 ] || kill "$PID"
- i="$((i + 1))"
- done
- # Use force
- if grep -q mysql "/proc/$PID/cmdline"; then
- kill -9 "$PID"
- fi
- fi
-
- # Start daemon
- procd_open_instance
-
- # shellcheck disable=SC2154 disable=SC2086
- procd_set_param command "$MYSQLD" $options
- procd_set_param respawn "${respawn_threshold:-3600}" "${respawn_timeout:-5}" "${respawn_retry:-5}"
- # run as user
- procd_set_param user "$my_user"
- # forward stderr to logd
- procd_set_param stderr 1
- # use HUP to reload
- procd_set_param reload_signal HUP
- # terminate using signals
- procd_set_param term_timeout 60
-
- procd_close_instance
- }
|