我想通过单击图标以 root 身份运行可执行文件。我有以下桌面文件 ( test.desktop
):
[Desktop Entry]
Version=1.0
Name=Test Program
Comment=Open test program
Exec=sudo taskset -c 7 /home/username/Desktop/folder1/test_program %f
Icon=/home/username/Desktop/folder1/image.png
Terminal=true
Type=Application
Categories=Utility;Application;
这可行,但每次我点击图标时,它都要求我输入密码,这越来越令人厌烦。我想要这一个图标以 root 身份执行此程序,无需密码提示。我不想禁用所有sudo
命令的密码提示。
test_program
以上是需要 root 状态才能正确运行的可执行文件。
此外,如果我将Exec=
上面的行更改为
Exec=gksudo -k -u root taskset -c 7 /home/username/Desktop/folder1/test_program %f
该程序实际上并没有运行,而是打开终端然后立即关闭终端。
我怎样才能以 root 身份运行它而不用每次都输入密码?
请求编辑#1:我编辑的 sudoers 文件如下所示。
#
# This file MUST be edited with the 'visudo' command as root.
#
# Please consider adding local content in /etc/sudoers.d/ instead of
# directly modifying this file.
#
# See the man page for details on how to write a sudoers file.
#
Defaults env_reset
Defaults mail_badpass
Defaults secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
# Host alias specification
# User alias specification
# Cmnd alias specification
# User privilege specification
root ALL=(ALL:ALL) ALL
# Members of the admin group may gain root privileges
%admin ALL=(ALL) ALL
# Allow members of group sudo to execute any command
%sudo ALL=(ALL:ALL) ALL
ALL ALL=NOPASSWD: /home/username/Desktop/folder1/test_program
# See sudoers(5) for more information on "#include" directives:
#includedir /etc/sudoers.d
答案1
ALL ALL=NOPASSWD: /home/username/Desktop/folder1/test_program
这不是您尝试运行的命令sudo
。该命令是:
taskset -c 7 /home/username/Desktop/folder1/test_program
(如果你点击启动器,它将%f
是空的,你最好将其删除)
因此,您需要更正文件sudoers
,但请记住,您需要使用绝对路径在这个答案中指出:
ALL ALL=NOPASSWD: /usr/bin/taskset -c 7 /home/username/Desktop/folder1/test_program
附注:此设置让每个用户taskset
使用给定的参数运行sudo
。这可能是也可能不是你想要的。