一:su 与 sudo 的使用


su是切换用户的命令,常用的方法是su - username
-是切换用户时,环境变量一起切换
sudo是普通用户可以执行只有root才能执行的命令,比如用普通用户自行sudo halt -p



如:普通用户切换到root用户的命令是
sudo su root,输入密码后,就会变成root@lab:/home/zhangping#,代表是root用户,普通用户是$符号。
sudo su root;和sudo su;是等价的,为空的话默认是root用户
但是如果sudo su -和 sudo su是不一样的,前面表示把环境变量也换到root用户即$PATH也改变(输入程序名时的查找路径)
输入sudo ,只输入su root 是不行的,因为普通用户没有这个权限,只有使用sudo命令才行



如:要使用root用户编辑文件 /etc/hosts
输入sudo gedit /etc/hosts即可
sudo 的主要配置文件是/etc/sudoers

命令名称:su 使用权限:所有使用者 使用方式:su [-fmp] [-c command] [-s shell] [--help] [--version] [-] [USER [ARG]] 
说明:变更为其他使用者的身份,除 root 外,需要键入该使用者的密码 
参数: 
-f 或 --fast 不必读启动档(如 csh.cshrc 等),仅用于 csh 或 tcsh 
-m -p 或 --preserve-environment 执行 su 时不改变环境变数 
-c command 或 --command=command 变更为帐号为 USER 的使用者并执行指令(command)后再变回原来使用者 
-s shell 或 --shell=shell 指定要执行的 shell (bash csh tcsh 等),预设值为 /etc/passwd 内的该使用者(USER) shell 
--help 显示说明文件 
--version 显示版本资讯 
- -l 或 --login 这个参数加了之后,就好像是重新 login 为该使用者一样,大部份环境变数(HOME SHELL USER等等)都是以该使用者(USER)为主,并且工作目录也会改变,如果没有指定 USER ,内定是 root 
USER 欲变更的使用者帐号 
ARG 传入新的 shell 参数


范例: 
su -c ls root 变更帐号为 root 并在执行 ls 指令后退出变回原使用者。 
su root -f 变更帐号为 root 并传入 -f 参数给新执行的 shell。 
su - clsung 变更帐号为 clsung 并改变工作目录至 clsung 的家目录(home dir)。




1.命令作用su的作用是变更为其它使用者的身份,超级用户除外,需要键入该使用者的密码。2.使用方式su [-fmp] [-c command] [-s shell] [--help] [--version] [-] [USER [ARG]]3.参数说明-f , –fast:不必读启动文件(如 csh.cshrc 等),仅用于csh或tcsh两种Shell。-l , –login:加了这个参数之后,就好像是重新登陆一样,大部分环境变量(例如HOME、SHELL和USER等)都是以该使用者(USER)为主,并且工作目录也会改变。如果没有指定USER,缺省情况是root。-m, -p ,–preserve-environment:执行su时不改变环境变数。-c command:变更账号为USER的使用者,并执行指令(command)后再变回原来使用者。–help 显示说明文件
–version 显示版本资讯USER:欲变更的使用者账号,
ARG:  传入新的Shell参数。4.例子su -c ls root 变更帐号为 root 并在执行 ls 指令后退出变回原使用者。su [用户名]a>在root用户下, 输入 su 普通用户. 则切换至普通用户, 从root切换到变通用户不需要密码b>在普通用户下, 输入 su [用户名]
提示 password:
输入用户的PASSWORD, 则切换至该用户扩展阅读一:Linux下 su命令与su - 命令有什么区别?su 是切换到其他用户,但是不切换环境变量(比如说那些export命令查看一下,就知道两个命令的区别了)su - 是完整的切换到一个用户环境所以建议大家切换用户的时候,尽量使用 su -  linuxso 这样 否则可能发现某些命令执行不了扩展阅读二:su和sudo的区别 由于su 对切换到超级权限用户root后,权限的无限制性,所以su并不能担任多个管理员所管理的系统。如果用su 来切换到超级用户来管理系统,也不能明确哪些工作是由哪个管理员进行的操作。特别是对于服务器的管理有多人参与管理时,最好是针对每个管理员的技术特长和 管理范围,并且有针对性的下放给权限,并且约定其使用哪些工具来完成与其相关的工作,这时我们就有必要用到 sudo。通过sudo,我们能把某些超级权限有针对性的下放,并且不需要普通用户知道root密码,所以sudo 相对于权限无限制性的su来说,还是比较安全的,所以sudo 也能被称为受限制的su ;另外sudo 是需要授权许可的,所以也被称为授权许可的su;sudo 执行命令的流程是当前用户切换到root(或其它指定切换到的用户),然后以root(或其它指定的切换到的用户)身份执行命令,执行完成后,直接退回到当前用户;而这些的前提是要通过sudo的配置文件/etc/sudoers来进行授权;