aboutsummaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorSebastian Kemper <sebastian_ml@gmx.net>2019-05-10 22:42:39 +0200
committerSebastian Kemper <sebastian_ml@gmx.net>2019-05-10 22:42:40 +0200
commit65036add44257bce77e04957ebc6e814e64e9314 (patch)
treeb735550a873875bca9c699222b28be2c904061d0 /utils
parent498ccc192c1eaa73162f90227aa9f71b12297214 (diff)
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>
Diffstat (limited to 'utils')
-rw-r--r--utils/mariadb/files/mysqld.init79
1 files changed, 67 insertions, 12 deletions
diff --git a/utils/mariadb/files/mysqld.init b/utils/mariadb/files/mysqld.init
index e55cfce70..66afb35bc 100644
--- a/utils/mariadb/files/mysqld.init
+++ b/utils/mariadb/files/mysqld.init
@@ -10,7 +10,7 @@ USE_PROCD=1
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
mysqld_get_param() {
@@ -24,7 +24,10 @@ mysqld_get_param() {
start_service() {
local conf=/etc/mysql/my.cnf
local dir
- local user=mariadb
+ local user
+ local group
+
+ local logfile
local datadir
local logdir=/var/log/mysql
@@ -36,6 +39,8 @@ start_service() {
local log_stdout
local options
+ local hint="please fix your server configuration in /etc/mysql/"
+
if [ ! -x $COMMAND ]; then
$LOGGER $COMMAND is missing
exit 1
@@ -60,30 +65,80 @@ start_service() {
config_get options general options
datadir=$(mysqld_get_param datadir)
+ logfile=$(mysqld_get_param general_log_file)
tmpdir=$(mysqld_get_param tmpdir)
+ user=$(mysqld_get_param user)
if [ -z "$datadir" ]; then
$LOGGER datadir is not set
+ $LOGGER $hint
exit 1
fi
if [ -z "$tmpdir" ]; then
- $LOGGER tmpdir is not set.
+ $LOGGER tmpdir is not set
+ $LOGGER $hint
exit 1
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
- if [ ! -e "$dir" ]; then
- mkdir -p "$dir"
- chown $user "$dir"
- fi
- done
+ user_exists "$user" || {
+ $LOGGER user \""$user"\" does not exist
+ $LOGGER $hint
+ exit 1
+ }
+
+ 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
- $LOGGER "cannot detect privileges table, you might need to"
- $LOGGER "run 'mysql_install_db --force' to initialize the system tables"
+ local args="--force"
+ 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
fi