3

是否有可能在没有 root 权限或具有 root 权限的情况下执行优雅重启并检查 apache 配置语法?

我已经尝试为suid执行重启的脚本设置位。这是脚本本身:

#!/bin/bash

FILENAME=$1
DATE=`date +%Y%m%d`
DIRECTORY='bckp/'
if [ ! -d "$DIRECTORY" ]; then
    echo "Backup directory doesn't exist. Creating one."
    mkdir $DIRECTORY
fi

if [ -z "$FILENAME" -a ! -f "$FILENAME" ]; then
    FILENAME="webdav.conf"
    echo "No file specified. Backing up webdav.conf"
fi

REV=0
BACKUP="$FILENAME.$DATE.$REV"

while [ -f $BACKUP ]; do
    let REV+=1
    BACKUP="$DIRECTORY$FILENAME.$DATE.$REV"
done

cp $FILENAME $BACKUP

echo $OUTPUT
OUTPUT=$(apache2ctl configtest 2>&1)
if [ "$OUTPUT" == "Syntax OK" ]; then
    echo "Syntax OK"
    echo "Performing restart"
    apachectl -k graceful 2>&1
fi

exit $?

这是ls -l这个文件的:

-rwsrwxr-x 1 root user  645 2012-04-26 18:05 graceful-restart

当我尝试运行此脚本时,我得到以下输出:

No file specified. Backing up webdav.conf
ulimit: 88: error setting limit (Operation not permitted) Syntax OK

如果可以执行我所描述的,我很感兴趣。

4

1 回答 1

9

Linux 不会尊重suidshell 脚本上的位。阅读内容以获取更多信息。

一个常见的解决方案是sudo命令。在这样的条目中/etc/sudoers

yourname ALL = NOPASSWD:/path/to/graceful-restart

你可以运行:

sudo /path/to/graceful-restart

这将在不提示您输入密码的情况下以 root 权限运行。有关文件语法的更多信息,请参见sudoers手册页。sudoers

于 2012-04-26T15:19:52.203 回答