У меня довольно странная проблема с sudo
в Debian 8. Пользователи не могут выполнять некоторые команды в /etc/sudoers.d
. Я использую Chef для распространения конфигураций, поэтому все файлы создаются автоматически.
Пример:
Эта конфигурация отлично работает
root@server:~# cat /etc/sudoers.d/nginx
# This file is managed by Chef.
# Do NOT modify this file directly.
user ALL=(root) NOPASSWD:/usr/sbin/nginx
И это не удается:
root@server:~# cat /etc/sudoers.d/update-rc.d
# This file is managed by Chef.
# Do NOT modify this file directly.
user ALL=(root) NOPASSWD:/usr/sbin/update-rc.d
user@www42:~$ sudo update-rc.d
[sudo] password for user:
Sorry, user user is not allowed to execute '/usr/sbin/update-rc.d' as root on server.
Что может быть не так?
Диагностика:
Mar 5 12:12:51 server sudo: user : command not allowed ; TTY=pts/0 ; PWD=/home/user ; USER=root ; COMMAND=/usr/sbin/update-rc.d
Mar 5 12:14:25 www42 su[1209]: pam_unix(su:session): session closed for user user
root@server:~# sudo --version
Sudo version 1.8.10p3
Configure options: --prefix=/usr -v --with-all-insults --with-pam --with-fqdn --with-logging=syslog --with-logfac=authpriv --with-env-editor --with-editor=/usr/bin/editor --with-timeout=15 --with-password-timeout=0 --with-passprompt=[sudo] password for %p: --disable-root-mailer --with-sendmail=/usr/sbin/sendmail --with-rundir=/var/lib/sudo --mandir=/usr/share/man --libexecdir=/usr/lib/sudo --with-sssd --with-sssd-lib=/usr/lib/x86_64-linux-gnu --with-selinux --with-linux-audit
Sudoers policy plugin version 1.8.10p3
Sudoers file grammar version 43
Проблема в точке в update-rc.d
(в /etc/sudoers.d/update-rc.d
); из man sudo
:
Директива #includedir может использоваться для создания каталога sudo.d, в который системный менеджер пакетов может помещать правила sudoers как часть установки пакета. Например, учитывая:
#includedir /etc/sudoers.d
sudo будет читать каждый файл в /etc/sudoers.d, пропуская имена файлов, которые заканчиваться на ~ или содержать. персонаж чтобы избежать проблем с менеджером пакетов или редактором временных / резервных файлов.
Попробуй и беги sudo -ll
чтобы получить список команд / config, применимых к вашему пользователю.
Если (что может показаться так) ваше предложение update-rc.d не отображается, вы можете подумать о корректировке своих рецептов повара для развертывания одного файла sudoers.d для каждого пользователя, а не нескольких.
Вы также можете подумать, нужен ли файл sudoers, связанный с группой.
Ответы на этот вопрос могут помочь: https://askubuntu.com/questions/246455/how-to-give-nopasswd-access-to-multiple-commands-via-sudoers