如何允许用户使用 sudo 保护环境?

And*_*inn 30 sudo sudoers

我遇到以下错误,试图在运行时允许某些环境变量传递到新环境sudo

sudo: sorry, you are not allowed to preserve the environment
Run Code Online (Sandbox Code Playgroud)

一些可能有助于调试的信息:

[deploy@worker1 ~]$ sudo -l
    Matching Defaults entries for deploy on this host:
    requiretty, !visiblepw, always_set_home, env_reset, env_keep="COLORS DISPLAY HOSTNAME HISTSIZE INPUTRC KDEDIR LS_COLORS", env_keep+="MAIL PS1 PS2 QTDIR USERNAME LANG LC_ADDRESS LC_CTYPE",
    env_keep+="LC_COLLATE LC_IDENTIFICATION LC_MEASUREMENT LC_MESSAGES", env_keep+="LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER LC_TELEPHONE", env_keep+="LC_TIME LC_ALL LANGUAGE LINGUAS _XKB_CHARSET
    XAUTHORITY", secure_path=/sbin\:/bin\:/usr/sbin\:/usr/bin, env_keep+="GIT_WORK_TREE GIT_DIR", !requiretty

User deploy may run the following commands on this host:
    (ALL) NOPASSWD: /usr/bin/git, (ALL) /etc/init.d/httpd*, (ALL) /sbin/service, (ALL) /usr/bin/make, (ALL) /bin/echo
Run Code Online (Sandbox Code Playgroud)

我的运行示例:

[deploy@worker1 ~]$ export GIT_DIR="/home/ashinn/testing"
[deploy@worker1 ~]$ sudo -E sh -c 'echo?"$GIT_DIR"'
sudo: sorry, you are not allowed to preserve the environment
Run Code Online (Sandbox Code Playgroud)

我的 sudoers.d 文件用于此特定配置:

Defaults:deploy         env_keep += "GIT_WORK_TREE GIT_DIR", !requiretty
deploy  ALL=(ALL)       NOPASSWD: /usr/bin/git, /etc/init.d/httpd*, /sbin/service, /usr/bin/make, /bin/echo
Run Code Online (Sandbox Code Playgroud)

我也尝试添加!env_reset到默认值,但它仍然失败并出现相同的错误。我觉得我可能遗漏了一些明显的东西,需要第二双眼睛。我在这里缺少什么?

iod*_*dbh 47

您可以SETENVsudoers文件中使用“标签” ,如:

deploy  ALL=(ALL)       SETENV: /usr/bin/git, /etc/init.d/httpd*, /sbin/service, /usr/bin/make, /bin/echo
Run Code Online (Sandbox Code Playgroud)

或者,将其与 NOPASSWD 结合使用:

deploy  ALL=(ALL)       NOPASSWD:SETENV: /usr/bin/git, /etc/init.d/httpd*, /sbin/service, /usr/bin/make, /bin/echo
Run Code Online (Sandbox Code Playgroud)

sudoers man 的相关摘录:

SETENV 和 NOSETENV

这些标签在每个命令的基础上覆盖 setenv 选项的值。请注意,如果已为命令设置了 SETENV,则用户可以通过 -E 选项从命令行禁用 env_reset 选项。此外,在命令行设置环境变量都没有受到规定的限制env_checkenv_deleteenv_keep。因此,应该只允许受信任的用户以这种方式设置变量。如果匹配的命令是 ALL,则该命令隐含了 SETENV 标记;可以使用 NOSETENV 标记覆盖此默认值。

  • 令人难以置信的是,对于同样的问题,有多少无用的答案。```SETENV:``` 帮我解决了这个问题。谢谢 (2认同)