跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 工具系统 > 防关联工具 > 【Linux】su、sudo 等 “切换用户” 命令

【Linux】su、sudo 等 “切换用户” 命令

时间:2024-04-09 07:05:32 来源:网络cs 作者:淼淼 栏目:防关联工具 阅读:

标签: 用户  命令 

【Linux】su、sudo 等 “切换用户” 命令

1.$ 和 # 区别2.su3.su -4.su - root5.sudo6.sudo -i7.sudo su -8.总结

1.$ 和 # 区别

$ 打头表示这不是在 root 用户(管理员用户)下执行的命令。

[ubuntu@Default:~]$ pwd/home/ubuntu[ubuntu@Default:~]$

# 打头的和前者相反,即 root 用户下。

[root@edge_detection:~]# pwd/root[root@edge_detection:~]#

如何使 $ 变为 #(就是将普通用户切换为 root 用户)?

[ubuntu@Default:~]$ sudo su[root@Default:/home/ubuntu]# exitexit[ubuntu@Default:~]$

2.su

su 命令可以用于 切换到其他用户的身份,默认情况下会切换到 root 用户身份。在使用 su 命令时需要输入 目标用户的密码 进行身份验证。

在 Ubuntu 中,使用 su 时需要先设置 root 用户的密码才能切换到其身份。

sudo passwd root    # 设置 root 用户密码su                  # 输入 root 用户密码切换到 root 用户身份

在 CentOS 中,su 命令默认将用户切换到与当前用户名同名的普通用户身份,如果不存在同名用户,则切换到 root 用户。如果需要切换到 root 用户身份,需要输入 root 用户的密码进行身份验证。

su                  # 输入 root 用户密码切换到 root 用户身份su username         # 切换到 username 用户身份

su 是最简单的身份切换命令,一般都是 su - username,然后输入 password 就 OK 了。root 用户通过 su 切换至其他用户无须密码,但非 root 用户切换时需要密码。切换到 root 可以使用 su -su - root

su [-] username -c 'COMMAND'
-c: 仅执行一次命令,而不切换用户身份。

3.su -

在 Ubuntu 和 CentOS 中,su - 命令也可以用于切换到其他用户的身份,但该命令会同时启动一个新的 shell 会话,并将环境变量设置为目标用户的环境变量。在使用 su - 命令时同样需要输入 目标用户的密码 进行身份验证。

su -                # 切换到 root 用户身份并启动新的 shell 会话su - username       # 切换到 username 用户身份并启动新的 shell 会话

注意区别:

su username         # 非登录式切换,即不会读取目标用户的配置文件su - username       # 登录式切换,会读取目标用户的配置文件(完全切换)

4.su - root

在 Ubuntu 和 CentOS 中,su - root 命令可以直接切换到 root 用户的身份,并启动一个新的 shell 会话。在使用该命令时需要输入 root 用户的密码进行身份验证。示例:

su - root           # 输入 root 用户密码切换到 root 用户身份并启动新的 shell 会话

5.sudo

sudo 是 Linux 系统管理指令,是允许系统管理员让普通用户执行一些或者全部的 root 命令的一个工具,如 haltrebootsu 等等。这样不仅减少了 root 用户的登录和管理时间,同样也提高了安全性。sudo 不是对 shell 的一个代替,它是面向每个命令的。

sudo 能够授权指定用户在指定主机上运行某些命令。 如果未授权用户尝试使用 sudo,会提示联系管理员。sudo 可以提供日志,记录每个用户使用 sudo 操作,以便于日后审计。sudo 为系统管理员提供配置文件,允许系统管理员集中地管理用户的使用权限和使用的主机。sudo 默认存活期为 5 5 5 分钟。

在 Ubuntu 和 CentOS 中,sudo 命令可以让普通用户以超级用户的权限执行特定命令。在使用 sudo 命令时需要输入 当前用户的密码 进行身份验证。

sudo command        # 用 sudo 权限执行 command 命令,需要输入当前用户密码验证身份

6.sudo -i

为了频繁的执行某些只有超级用户才能执行的权限,而不用每次输入密码,可以使用该命令。提示输入密码时该密码为当前账户的密码。没有时间限制。执行该命令后提示符变为 # 而不是 $。想退回普通账户时可以执行 exitlogout

在 Ubuntu 和 CentOS 中,sudo -i 命令可以启动一个新的 shell 会话,并将环境变量设置为 root 用户的环境变量。在使用该命令时同样需要输入 当前用户的密码 进行身份验证。

sudo -i             # 输入当前用户密码切换到 root 用户身份并启动新的 shell 会话

sudo -isudo -i rootsudo -sudo - rootsudo root 效果相同,提示输入密码时,该密码为当前账户的密码,并且要求执行该命令的用户必须在 sudoers 中才可以。

7.sudo su -

在 Ubuntu 和 CentOS 中,sudo su - 命令可以用于直接切换到 root 用户的身份,并启动一个新的 shell 会话。在使用该命令时同样需要输入 当前用户的密码 进行身份验证。

sudo su -           # 输入当前用户密码切换到 root 用户身份并启动新的 shell 会话

8.总结

总的来说,这些命令在 Ubuntu 和 CentOS 中的用法基本相同,但具体行为会略有不同。建议在使用这些命令时先了解其具体行为和安全性问题,以避免潜在的风险和影响。

su 方式切换是须要输入 目标用户的密码。而 sudo 仅仅须要输入 自己的密码,所以 sudo 能够保护目标用户的密码不对外泄漏。sudo 授权 passwdsusudosudoeditvisudo 等具有特殊意义的命令时,务必要考虑全面(例如禁止修改 root 用户的密码等操作)。

本文链接:https://www.kjpai.cn/news/2024-04-09/155739.html,文章来源:网络cs,作者:淼淼,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论