230 lines
5.9 KiB
Plaintext
230 lines
5.9 KiB
Plaintext
|
#!/bin/bash
|
||
|
#
|
||
|
# Copyright (c) 2017, Philip Kovacs
|
||
|
# All rights reserved.
|
||
|
#
|
||
|
# Redistribution and use in source and binary forms, with or without
|
||
|
# modification, are permitted provided that the following conditions are met:
|
||
|
#
|
||
|
# 1. Redistributions of source code must retain the above copyright notice, this
|
||
|
# list of conditions and the following disclaimer.
|
||
|
# 2. Redistributions in binary form must reproduce the above copyright notice,
|
||
|
# this list of conditions and the following disclaimer in the documentation
|
||
|
# and/or other materials provided with the distribution.
|
||
|
#
|
||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||
|
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||
|
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||
|
# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||
|
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||
|
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||
|
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
|
||
|
prog=`basename $0`
|
||
|
user=root
|
||
|
group=root
|
||
|
yesno=no
|
||
|
|
||
|
red='\033[0;31m'
|
||
|
green='\033[0;32m'
|
||
|
nc='\033[0m'
|
||
|
pass="${green}[*]${nc}"
|
||
|
fail="${red}[!]${nc}"
|
||
|
ask="[?]"
|
||
|
|
||
|
# the rpm spec configures these directory variables
|
||
|
dir_conf="%{_sysconfdir}/%{name}"
|
||
|
dir_log="%{_var}/log/%{name}"
|
||
|
dir_run="%{_rundir}/%{name}"
|
||
|
dir_spool="%{_var}/spool/%{name}"
|
||
|
dir_tmpfiles_d="%{_tmpfilesdir}"
|
||
|
|
||
|
file_slurm_conf="${dir_conf}/slurm.conf"
|
||
|
file_slurmdbd_conf="${dir_conf}/slurmdbd.conf"
|
||
|
file_tmpfiles_d_conf="${dir_tmpfiles_d}/slurm.conf"
|
||
|
|
||
|
function usage ()
|
||
|
{
|
||
|
echo -e "Sets the slurm installation on this node to run as the specified user and group\n"
|
||
|
echo "Usage: $prog [-u <user>] [-g <group>] [-h] [-y]"
|
||
|
echo " -u user> : the slurm file owner and SlurmUser ($user)"
|
||
|
echo " -g <group> : the slurm file group ($group)"
|
||
|
echo " -y : answer yes to all questions ($yesno)"
|
||
|
echo " -h : print help"
|
||
|
}
|
||
|
|
||
|
function answer ()
|
||
|
{
|
||
|
while true
|
||
|
do
|
||
|
if [ "${yesno}" = "yes" ]; then
|
||
|
echo -e "${ask} $1 [${yesno}]"
|
||
|
__answer="yes"
|
||
|
break;
|
||
|
fi
|
||
|
|
||
|
echo -e -n "${ask} "
|
||
|
read -e -p "$1 [${yesno}] " yn
|
||
|
case $yn in
|
||
|
"") __answer=$yesno
|
||
|
break;;
|
||
|
[yY]*) __answer="yes"
|
||
|
break;;
|
||
|
[nN]*) __answer="no"
|
||
|
break;;
|
||
|
*)
|
||
|
echo "Please answer yes or no";;
|
||
|
esac
|
||
|
done
|
||
|
}
|
||
|
|
||
|
#
|
||
|
# Parse options
|
||
|
#
|
||
|
while getopts "u:g:yh" opt
|
||
|
do
|
||
|
case "$opt" in
|
||
|
h)
|
||
|
usage
|
||
|
exit 2;;
|
||
|
u)
|
||
|
user=$OPTARG;;
|
||
|
g)
|
||
|
group=$OPTARG;;
|
||
|
y)
|
||
|
yesno=yes;;
|
||
|
*)
|
||
|
echo ""
|
||
|
usage
|
||
|
exit 2;;
|
||
|
esac
|
||
|
done
|
||
|
|
||
|
#
|
||
|
# Run this script only as root
|
||
|
#
|
||
|
if [ $UID -eq 0 ]; then
|
||
|
echo -e "${pass} running as root... good"
|
||
|
else
|
||
|
echo -e "${fail} $prog must be run as root."
|
||
|
exit 1
|
||
|
fi
|
||
|
|
||
|
#
|
||
|
# Validate the user and group
|
||
|
#
|
||
|
valid_user="`getent passwd $user || :`"
|
||
|
if [ -n "$valid_user" ]; then
|
||
|
echo -e "${pass} found user $user... good"
|
||
|
else
|
||
|
echo -e "${fail} the specified user was not found... ${user}"
|
||
|
exit 2
|
||
|
fi
|
||
|
valid_group="`getent group $group || :`"
|
||
|
if [ -n "$valid_group" ]; then
|
||
|
echo -e "${pass} found group $group... good"
|
||
|
else
|
||
|
echo -e "${fail} the specified group was not found... ${group}"
|
||
|
exit 2
|
||
|
fi
|
||
|
|
||
|
#
|
||
|
# Slurm services must not be running
|
||
|
#
|
||
|
slurmctld_running_pid="`ps -e | grep slurmctld | grep -v grep | awk '{print $1}'`"
|
||
|
if [ -z "$slurmctld_running_pid" ]; then
|
||
|
echo -e "${pass} slurmctld is not running... good"
|
||
|
else
|
||
|
echo -e "${fail} slurmctld is running... stop it with [systemctl stop slurmctld]"
|
||
|
exit 2
|
||
|
fi
|
||
|
slurmd_running_pid="`ps -e | grep slurmd | grep -v grep | awk '{print $1}'`"
|
||
|
if [ -z "$slurmd_running_pid" ]; then
|
||
|
echo -e "${pass} slurmd is not running... good"
|
||
|
else
|
||
|
echo -e "${fail} slurmd is running... stop it with [systemctl stop slurmd]"
|
||
|
exit 2
|
||
|
fi
|
||
|
slurmdbd_running_pid="`ps -e | grep slurmdbd | grep -v grep | awk '{print $1}'`"
|
||
|
if [ -z "$slurmdbd_running_pid" ]; then
|
||
|
echo -e "${pass} slurmdbd is not running... good"
|
||
|
else
|
||
|
echo -e "${fail} slurmdbd is running... stop it with [systemctl stop slurmdbd]"
|
||
|
exit 2
|
||
|
fi
|
||
|
|
||
|
#
|
||
|
# Update SlurmUser in the slurm configs
|
||
|
#
|
||
|
for file in "$file_slurm_conf" "$file_slurmdbd_conf"
|
||
|
do
|
||
|
if [ -f "$file" ]; then
|
||
|
answer "update SlurmUser in $file ?"
|
||
|
if [ "$__answer" = "yes" ]; then
|
||
|
sed -i "s|^SlurmUser=.*|SlurmUser=${user}|g" $file
|
||
|
if [ $? -eq 0 ]; then
|
||
|
echo -e "${pass} $file updated successfully"
|
||
|
else
|
||
|
echo -e "${fail} error updating $file"
|
||
|
exit 1
|
||
|
fi
|
||
|
fi
|
||
|
fi
|
||
|
done
|
||
|
|
||
|
#
|
||
|
# Update ownership of slurm directories that must be owned by the slurm user
|
||
|
#
|
||
|
for dir in "$dir_log" "$dir_run" "$dir_spool" "$dir_spool/ctld"
|
||
|
do
|
||
|
if [ -d "$dir" ]; then
|
||
|
answer "update ownership of $dir ?"
|
||
|
if [ "$__answer" = "yes" ]; then
|
||
|
chown ${user}:${group} $dir
|
||
|
if [ $? -eq 0 ]; then
|
||
|
echo -e "${pass} $dir updated successfully"
|
||
|
else
|
||
|
echo -e "${fail} error updating $dir"
|
||
|
exit 1
|
||
|
fi
|
||
|
fi
|
||
|
fi
|
||
|
done
|
||
|
|
||
|
#
|
||
|
# Update ownership of slurmctld spool files which are owned by the slurm user
|
||
|
#
|
||
|
if [ -d "${dir_spool}/ctld" ]; then
|
||
|
answer "update ownership of files in ${dir_spool}/ctld ?"
|
||
|
if [ "$__answer" = "yes" ]; then
|
||
|
if [ $? -eq 0 ]; then
|
||
|
find ${dir_spool}/ctld -mindepth 1 -exec chown ${user}:${group} {} \;
|
||
|
echo -e "${pass} ${dir_spool}/ctld files updated successfully"
|
||
|
else
|
||
|
echo -e "${fail} error updating ${dir_spool}/ctld files"
|
||
|
exit 1
|
||
|
fi
|
||
|
fi
|
||
|
fi
|
||
|
|
||
|
#
|
||
|
# Update the tmpfiles.d config file to the new slurm user
|
||
|
#
|
||
|
if [ -f "$file_tmpfiles_d_conf" ]; then
|
||
|
answer "update tmpfiles.d config $file_tmpfiles_d_conf ?"
|
||
|
if [ "$__answer" = "yes" ]; then
|
||
|
sed -i "s|0755 \(.*\) -$|0755 ${user} ${group} -|g" $file_tmpfiles_d_conf
|
||
|
if [ $? -eq 0 ]; then
|
||
|
echo -e "${pass} $file_tmpfiles_d_conf updated successfully"
|
||
|
else
|
||
|
echo -e "${fail} error updating $file_tmpfiles_d_conf"
|
||
|
exit 1
|
||
|
fi
|
||
|
fi
|
||
|
fi
|
||
|
|
||
|
exit 0
|