Я сталкиваюсь со следующей ошибкой, пытаясь разрешить некоторым переменным среды проходить в новую среду при запуске sudo
:
sudo: sorry, you are not allowed to preserve the environment
Некоторая информация, которая может быть полезна для отладки:
[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
Мой бегущий пример:
[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
Мой файл 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
Я также попытался добавить !env_reset
к значениям по умолчанию, и он по-прежнему не удается с той же ошибкой. Я чувствую, что могу упустить что-то очевидное и мне нужен второй набор глаз. Что мне здесь не хватает?
sudo
(option(s))
echo $GIT_DIR
sudo
$GIT_DIR
sudo
sudo printenv GIT_DIR
sudo env | grep GIT_DIR
sudo sh -c 'echo "$GIT_DIR"'
Ответы:
Вы можете использовать
SETENV
тег в вашемsudoers
файле, например:Или, чтобы объединить это с NOPASSWD:
Соответствующий отрывок из sudoers man:
источник
Не указывайте
-E
опцию. Используя,-E
вы говорите, что все переменные окружения для пользователяdeploy
должны быть сохранены, а не толькоGIT_DIR
Запуск
sudo echo $GIT_DIR
должен работать, потому что вы добавилиGIT_DIR
вenv_keep
списокисточник