Commit efa3b3de authored by Otto Kekäläinen's avatar Otto Kekäläinen Committed by Jan Lindström

MDEV-22159: Don't redirect as root to a tmp file not owned by root

Also add a check for tmp file being empty and bail out with a clear
error message in such a case, as mysqld_safe prevents normal stderr
from being displayed anywhere and would fail silently on this.
parent a6a8774d
...@@ -263,7 +263,9 @@ wsrep_recover_position() { ...@@ -263,7 +263,9 @@ wsrep_recover_position() {
fi fi
if [ -f $wr_logfile ]; then if [ -f $wr_logfile ]; then
[ "$euid" = "0" ] && chown $user $wr_logfile # NOTE! Do not change ownership of the temporary file, as on newer kernel
# versions fs.protected_regular is set to '2' and redirecting output with >
# as root to a file not owned by root will fail with "Permission denied"
chmod 600 $wr_logfile chmod 600 $wr_logfile
else else
log_error "WSREP: mktemp failed" log_error "WSREP: mktemp failed"
...@@ -278,6 +280,11 @@ wsrep_recover_position() { ...@@ -278,6 +280,11 @@ wsrep_recover_position() {
eval "$mysqld_cmd --wsrep_recover $wr_options 2> $wr_logfile" eval "$mysqld_cmd --wsrep_recover $wr_options 2> $wr_logfile"
if [ ! -s "$wr_logfile" ]; then
log_error "Log file $wr_logfile was empty, cannot proceed. Is system running fs.protected_regular?"
exit 1
fi
local rp="$(grep 'WSREP: Recovered position:' $wr_logfile)" local rp="$(grep 'WSREP: Recovered position:' $wr_logfile)"
if [ -z "$rp" ]; then if [ -z "$rp" ]; then
local skipped="$(grep WSREP $wr_logfile | grep 'skipping position recovery')" local skipped="$(grep WSREP $wr_logfile | grep 'skipping position recovery')"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment