肯定有人不知道下面两个命令的区别:
1 | [warmcolor@PC ~]$ su |
那下面两个命令的区别呢?
1 | [warmcolor@PC ~]$ su |
首先,su,su -这两个命令都能获得root权限,
但root的密码是不能随便交给别人的,这时就需要sudo命令了,
使用用户自己的密码,临时赋予一般用户root权限,
sudo的运行过程是这样的:
检查用户是否在/etc/sudoers的列表中,
如果在,以root权限执行命令,
取消用户的root
接着说说这三个命令的区别:
下面是su的过程:
1 | [warmcolor@PC ~]$ su |
下面是su - 的过程:
1 | [warmcolor@PC ~]$ su - |
下面是sudo的过程:
1 | [warmcolor@PC ~]$ sudo pwd |
可以看出su和sudo没有切换工作目录和环境变量,只是赋予用户权限,
而su -是真正切换到root登录,工作目录切换到/root,环境变量也同时改变.
而网上还有一个说法,sudo 默认将原有的环境变量 reset,只保留一些对安全没有影响设定.
至于上面第二个问题,答案其实很简单,
同样切换到root登录,
su使用root的密码,而sudo su使用用户密码.
上述命令更为具体的描述请参见man手册.
原文链接:http://blog.warmcolor.net/?p=3542
转载本站文章请注明,转载自:温暖色调[http://blog.warmcolor.net ]
sudo命令报:xxx is not in the sudoers file.This incident will be reported.的解决方法
1.切换到root用户下,怎么切换就不用说了吧,不会的自己百度去.
2.添加sudo文件的写权限,命令是:
chmod u+w /etc/sudoers
3.编辑sudoers文件
vi /etc/sudoers
找到这行 root ALL=(ALL) ALL,在他下面添加xxx ALL=(ALL) ALL (这里的xxx是你的用户名)
ps:这里说下你可以sudoers添加下面四行中任意一条
youuser ALL=(ALL) ALL
%youuser ALL=(ALL) ALL
youuser ALL=(ALL) NOPASSWD: ALL
%youuser ALL=(ALL) NOPASSWD: ALL
第一行:允许用户youuser执行sudo命令(需要输入密码).
第二行:允许用户组youuser里面的用户执行sudo命令(需要输入密码).
第三行:允许用户youuser执行sudo命令,并且在执行的时候不输入密码.
第四行:允许用户组youuser里面的用户执行sudo命令,并且在执行的时候不输入密码.
4.撤销sudoers文件写权限,命令:
chmod u-w /etc/sudoers
这样普通用户就可以使用sudo了.