Linux中sudo不用输入密码的方法是什么

79次阅读
没有评论

共计 2910 个字符,预计需要花费 8 分钟才能阅读完成。

这篇文章主要讲解了“Linux 中 sudo 不用输入密码的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“Linux 中 sudo 不用输入密码的方法是什么”吧!

解决办法一:
在启动时进入安全模式,这时是用 root 登录的,执行:

chmod 740 /etc/sudoers

然后打开 /etc/sudoers 这个文件,把最后一行:

%admin ALL=(ALL)
%%admin ALL=(ALL) NOPASSWD: NOPASSWD: ALL

保存退出。
执行:

chmod 0440 /etc/sudoers
reboot your ubuntu.OK!

解决方法二:
Ubuntu 默认不能直接用 root 帐户登录, 必须从第一个创建的用户 (既安装时创建的那个用户) 通过 su 或 sudo 来获得 root 权限。在 Ubuntu 中对系统进行操作很多时候都要使用这个命令,由此可见对于新来说很有必要来认识这个命令。这或许不太方便,但这样增加了安全性,避免用户由于误操作而损坏系统。

sudo
格式:sudo [其它命令]

sudo 既为 Super user do 的意思。sudo 在这个过程中只起一个调用 root 用户的作用,本次操作完成后,其作用就消失,如果要使用调用 root 权限操作的命令就必须再次使用 sudo。些过程中系统会要求用户输入密码,此密码就是安装系统时你输入你那个密码,注意:这个密码在输入你时候不会像在 Windows 里输密码那样输入一位密码就有一个 * 号,这样的目的就是为了使密码更安全,因为不知道你密码有几位这样无疑给密码破译者增加了难度。:)

例:

我们要更改当前目录下 upload.tar.gz 的权限就要用到 sudo。如果还要对当前目录下的另外一个文件 eva.tar.gz 更改权限就要再次用到 sudo。

ownlinux@server:/var/www$ sudo chmod 777 upload.tar.gz
[sudo] password for ownlinux: (此时输入你的密码)ownlinux@server:/var/www$ sudo chmod 777 eva.tar.gz
[sudo] password for ownlinux:

补充:
通常我们并不以 root 身份登录,但是当我们执行某些命令 (command)时需要用到 root 权限,我们通常都是用 sudo command 来执行 command。由于使用 Ubuntu,所以经常都都用 sudo,而使用 sudo 时,又得输入密码,所以我就寻找 sudo 不输入密码的方法。前阵子 google 了一下,很容容易找到一个方法,但是对其不够理解,今天,仔细研究了一下 /etc/sudoers 这个文件,对于如何实现自己的需求就非常清楚了。网上说看到的资料往往写得不清楚,所以我根据自己的需求好好整理了一下。
假设我的用户名为 jay(属于 admin 组),使 sudo 不用密码的方法如下。
运行命令:sudo visudo 或者 sudo vi /etc/sudoers,如果 vi 来编辑,则保存时记得用 wq! 强制保存,否则会提示只读不能保存的。
就会编辑 /etc/sudoers 这个文件。默认情况我们会看到有 %admin ALL=(ALL) ALL 一句话,就是允许 admin 组在所有主机上执行所有命令,当然是需要 passwd 的。
1. 如果想把 admin 组的用户都 sudo 不用密码那么可以将这一行换为:%admin ALL=(ALL) NOPASSWD: NOPASSWD ALL 即可。
2. 如果仅仅想让 jay 用户 sudo 不需密码,则可添加 jay ALL = NOPASSWD: ALL 这样一行。
3. 如果让 jay 用户 sudo 不用密码即可执行某几个命令,可这样写 jay ALL = NOPASSWD: /usr/bin/abc.sh, /usr/sbin/adduser
4. 欲知其? 更多配置方式,请运行 man sudoers 看帮助文档吧。
注意:我自己的一个配置没生效,找原因还找了阵子,写到这里吧。
我添加 jay ALL = NOPASSWD: ALL 这样一行;但是,jay 执行 sudo 时还是需要输入密码,这是为什么?
原来是,我这一行在 %admin ALL=(ALL) ALL 组策略之前前,后面的组配置覆盖了前面的配置,而 jay 属于 admin 组,所以需要密码。
这时,只需要将 %admin 行用 #注释掉即可。OK!然后立马就生效?,可能执行 sudo 时系统都会去读取 /etc/sudoers 的,所以立即就生效了。
另外,附带公司某服务器的一个 /etc/sudoers 配置:

Defaults env_reset
Defaults syslog=auth
Defaults log_year,logfile=/var/log/sudo.log
User_Alias ABC = abc
Cmnd_Alias DEFAULT=/bin/*,/sbin/ldconfig,/sbin/ifconfig,/usr/sbin/useradd,/usr/sbin/userdel,/bin/rpm,/usr/bin/yum,/sbin/service,/sbin/chkconfig,sudoedit /etc/rc.local,sudoedit /etc/hosts,sudoedit /etc/ld.so.conf,/bin/mount,sudoedit /etc/exports,/usr/bin/passwd [!-]*,!/usr/bin/passwd root,/bin/su - [!-]*,!/bin/su - root,!/bin/su root,/bin/bash,/usr/sbin/dmidecode,/usr/sbin/lsof,/usr/bin/du,/usr/bin/python,/usr/sbin/xm,sudoedit /etc/profile,sudoedit /etc/bashrc,/usr/bin/make,sudoedit /etc/security/limits.conf,/etc/init.d/*,/usr/bin/ruby
ABC ALL=(ALL)NOPASSWD:DEFAULT

通过修改 /etc/sudoers

sudo vi /etc/sudoers
把 /etc/sudoers 里最后一行
%admin ALL=(ALL)
%admin ALL=(ALL) NOPASSWD: NOPASSWD: ALL

然后强制保存 wq 就 OK
上面说的并不准确,要注意以下几点。
编辑 /etc/sudoers 文件使用“超级用户终端”,而不能使用普通的终端。“超级用户终端”启动通过右键“编辑菜单”命令添加。
编辑完之后使用 wq! 而不是 wq 退出

感谢各位的阅读,以上就是“Linux 中 sudo 不用输入密码的方法是什么”的内容了,经过本文的学习后,相信大家对 Linux 中 sudo 不用输入密码的方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计2910字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)