有一个命令列表,只有当它们前面带有以下内容时才会成功sudo
.
还有另一个命令列表,只有当用户运行它们而没有sudo
.
我想从同一个脚本执行所有这些命令。
我想避免执行以下操作:
#!/usr/bin/env bash
sudo sudo_command_one;
sudo sudo_command_two;
sudo sudo_command_three;
non_sudo_command;
sudo sudo_command_four;
这样做的原因是因为 sudo 有超时,并且这些命令可能会花费很长时间。我不想承受偶尔重新输入 sudo 密码的负担。我也许可以无限期地延长 sudo 的超时时间,但如果有更简单的方法,我也希望避免这种情况。
因此,我将像这样运行脚本:
sudo ./script
但这会阻止非 sudo 命令运行。
我需要什么缺少的命令:
#!/usr/bin/env bash
sudo_command_one;
sudo_command_two;
sudo_command_three;
[turn sudo off for a moment]
non_sudo_command;
[ok, turn sudo back on]
sudo_command_four;
不幸的是,命令的顺序无法重新排列,因此我首先运行所有 sudo 命令,然后运行所有非 sudo 命令(反之亦然)。
在 sudo 运行的脚本中,使用:
su -c "shell command; shell command" $SUDO_USER
在该脚本中以调用 sudo 的普通用户身份执行命令。
这有效是因为sudo
设置环境变量SUDO_USER
到原来的用户名。
如果您有一堆命令要以原始用户身份运行,则可以使用此处文档。
以下是作为概念证明的示例脚本文件:
myscript.sh
#!/bin/bash
echo "Part 1"
echo "now running as:"
whoami
echo "SUDO_USER is:"
echo $SUDO_USER
su $SUDO_USER <<EOF
echo "Part 2"
echo "now running as:"
whoami
echo "SUDO_USER is:"
env | grep ^SUDO_USER
sleep 5
EOF
echo "Part 3"
echo "now running as:"
whoami
echo "SUDO_USER is:"
echo $SUDO_USER
这是输出sudo ./myscript.sh
Part 1
now running as:
root
SUDO_USER is:
paul
Part 2
now running as:
paul
SUDO_USER is:
SUDO_USER=paul
Part 3
now running as:
root
SUDO_USER is:
paul
警告:此技术不适用于嵌套 sudo。如果 sudo 嵌套两次,例如
sudo su
echo $SUDO_USER
---> me
sudo su
echo $SUDO_USER
---> root
SUDO_USER 将返回 root,而不是原始用户名。 su $SUDO_USER 然后将继续以 root 身份运行。小心避免这种情况,它应该可以正常工作。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)