mariadb: init script update

- added trailing '--' to logger to make it foolproof
- user is extracted from config instead of using hard-coded value
- log directory is now also extracted from config (if set)
- directory creation is now done via awk script (more robust)
- improved log messages

Signed-off-by: Sebastian Kemper <sebastian_ml@gmx.net>
This commit is contained in:
Sebastian Kemper 2019-05-10 22:42:39 +02:00
parent 498ccc192c
commit 65036add44
1 changed files with 67 additions and 12 deletions

View File

@ -10,7 +10,7 @@ USE_PROCD=1
NAME=mysqld NAME=mysqld
LOGGER="/usr/bin/logger -p user.err -s -t $NAME" LOGGER="/usr/bin/logger -p user.err -s -t $NAME --"
COMMAND=/usr/bin/$NAME COMMAND=/usr/bin/$NAME
mysqld_get_param() { mysqld_get_param() {
@ -24,7 +24,10 @@ mysqld_get_param() {
start_service() { start_service() {
local conf=/etc/mysql/my.cnf local conf=/etc/mysql/my.cnf
local dir local dir
local user=mariadb local user
local group
local logfile
local datadir local datadir
local logdir=/var/log/mysql local logdir=/var/log/mysql
@ -36,6 +39,8 @@ start_service() {
local log_stdout local log_stdout
local options local options
local hint="please fix your server configuration in /etc/mysql/"
if [ ! -x $COMMAND ]; then if [ ! -x $COMMAND ]; then
$LOGGER $COMMAND is missing $LOGGER $COMMAND is missing
exit 1 exit 1
@ -60,30 +65,80 @@ start_service() {
config_get options general options config_get options general options
datadir=$(mysqld_get_param datadir) datadir=$(mysqld_get_param datadir)
logfile=$(mysqld_get_param general_log_file)
tmpdir=$(mysqld_get_param tmpdir) tmpdir=$(mysqld_get_param tmpdir)
user=$(mysqld_get_param user)
if [ -z "$datadir" ]; then if [ -z "$datadir" ]; then
$LOGGER datadir is not set $LOGGER datadir is not set
$LOGGER $hint
exit 1 exit 1
fi fi
if [ -z "$tmpdir" ]; then if [ -z "$tmpdir" ]; then
$LOGGER tmpdir is not set. $LOGGER tmpdir is not set
$LOGGER $hint
exit 1 exit 1
fi fi
[ -e "$datadir" ] || mkdir -p "$datadir" if [ -z "$user" ]; then
$LOGGER user is not set
$LOGGER $hint
exit 1
fi
for dir in "$logdir" "$rundir" "$tmpdir"; do user_exists "$user" || {
if [ ! -e "$dir" ]; then $LOGGER user \""$user"\" does not exist
mkdir -p "$dir" $LOGGER $hint
chown $user "$dir" exit 1
fi }
done
group=$(id -g -n "$user")
group_exists "$group" || {
$LOGGER group \""$group"\" does not exist
$LOGGER user \""$user"\" not configured correctly
exit 1
}
[ -n "$logfile" ] && logdir=$(dirname "$logfile")
# do not touch directories that already exist
# posix shell does not support arrays, hence using awk
awk \
-v user="$user" \
-v group="$group" \
-v a="$datadir" \
-v b="$logdir" \
-v c="$rundir" \
-v d="$tmpdir" \
'
BEGIN {
dir[0]=a
dir[1]=b
dir[2]=c
dir[3]=d
for (x in dir) {
if (system("test ! -e \"" dir[x] "\"" )) {
delete dir[x]
}
}
for (x in dir) {
system("mkdir -p \"" dir[x] "\"" )
system("chmod 750 \"" dir[x] "\"" )
system("chown \"" user "\":\"" group "\" \"" dir[x] "\"" )
}
}
'
if [ ! -f "$datadir/mysql/tables_priv.MYD" ]; then if [ ! -f "$datadir/mysql/tables_priv.MYD" ]; then
$LOGGER "cannot detect privileges table, you might need to" local args="--force"
$LOGGER "run 'mysql_install_db --force' to initialize the system tables" local 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 exit 1
fi fi