#!/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 ] [-g ] [-h] [-y]" echo " -u user> : the slurm file owner and SlurmUser ($user)" echo " -g : 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