Bootstrap

Linux---用户切换命令(su命令、sudo命令、exit命令)

1. su命令

root用户拥有最大的系统操作权限,而普通用户在许多地方的权限是受限的。

普通用户的权限,一般在其HOME目录内是不受限的。

一旦出了HOME目录,大多数地方,普通用户仅有只读和执行权限,无修改权限。

su 是最简单的用户切换命令,通过该命令可以实现任何身份的切换,包括从普通用户切换为 root

用户、从 root 用户切换为普通用户以及普通用户之间的切换。

普通用户之间切换以及普通用户切换至 root 用户,都需要知晓对方的密码,只有正确输入密码,

才能实现切换;从 root 用户切换至其他用户,无需知晓对方密码,直接可切换成功。

su命令就是用于账户切换的系统命令,其来源英文单词:Switch User

语法: su [选项] 用户名

选项包括:

-:当前用户不仅切换为指定用户的身份,同时所用的工作环境也切换为此用户的环境(包括

PATH 变量、MAIL 变量等),使用 - 选项可省略用户名,默认会切换为 root 用户。

-l:同 - 的使用类似,也就是在切换用户身份的同时,完整切换工作环境,但后面需要添加欲切换

的使用者账号。

-p:表示切换为指定用户的身份,但不改变当前的工作环境(不使用切换用户的配置文件)。

-c 命令:仅切换用户执行一次命令,执行后自动切换回来,该选项后通常会带有要执行的命令。

 切换用户后,可以通过exit命令退回上一个用户,也可以使用快捷键:ctrl + d

[shaonian@localhost ~]$ whoami
shaonian

[shaonian@localhost ~]$ su - shaonian1
Password:   

[shaonian1@localhost ~]$ whoami
shaonian1

[shaonian1@localhost ~]$ exit
logout
[shaonian@localhost ~]$ whoami
shaonian

注意:使用 su 命令时,有 - 和没有 - 是完全不同的,- 选项表示在切换用户身份的同时,连当前使

用的环境变量也切换成指定用户的。我们知道,环境变量是用来定义操作系统环境的,因此如果系

统环境没有随用户身份切换,很多命令无法正确执行。在不使用 su - 的情况下,虽然用户身份成

功切换,但环境变量依旧用的是原用户的,切换并不完整。

2. sudo命令

在得知root密码的时候,可以通过su命令切换到root得到最大权限。

但是不建议长期使用root用户,避免带来系统损坏。

可以使用sudo命令,为普通的命令授权,临时以root身份执行。

语法:sudo 其他命令

在其它命令之前,带上 sudo,即可为这一条命令临时赋予 root 授权。

但是并不是所有的用户,都有权利使用 sudo,我们需要为普通用户配置 sudo 认证:

       切换到root用户,执行visudo命令,会自动通过vi编辑器打开:/etc/sudoers

       在文件的最后添加:shaonian ALL=(ALL)   NOPASSWD: ALL

       其中最后的NOPASSWD: ALL 表示使用sudo命令,无需输入密码,shaonian是用户名,

       最后通过 wq 保存,切换回普通用户,执行的命令,均以root运行。

参数说明:

#列出目前的权限
[shaonian@localhost ~]$ sudo -l
#列出 sudo 的版本资讯
[shaonian@localhost ~]$ sudo -V
#sudo命令使用
[shaonian@localhost ~]$ sudo ls

3. exit命令

Linux exit命令用于退出目前的shell。

执行exit可使shell以指定的状态值退出。若不设置状态值参数,则shell以预设值退出。状态值0代

表执行成功,其他值代表执行失败。exit也可用在script,离开正在执行的script,回到shell。

;