Linux 中 root 与 sudo 的用法与区别,居然这么多人搞不清楚!

linux系统中,有两个概念可能大家比较熟悉,一个是sudo命令,另一个是root账户。sudo命令可以让我们以最高权限执行命令,而在root账户下,所有命令都具有最高权限,相当于所有命令都默认加了sudo。

Linux 中 root 与 sudo 的用法与区别,居然这么多人搞不清楚!

那么,sudo和root之间的区别到底是什么呢?为什么我们建议使用sudo而不是直接使用root账户?在本教程中,您将学习到有关root访问、sudo命令、如何使用sudo运行命令以及sudo访问和root之间的区别。

什么是 root?

root 是指 Linux 等类 Unix 系统中的超级用户帐户。它是用于系统管理的系统上具有最高访问权限的特权帐户。此根/超级用户帐户的用户标识符 (UID) 为零,无论帐户名称如何。

root 用户拥有整个系统的完全权限(root 特权)。它可以做诸如修改系统的核心部分、升级系统、更改系统配置以及启动、停止和重新启动所有正在运行的系统服务之类的事情。

以 root 身份登录(使用 su -)时,终端命令提示符符号从

$ echo 'You are in a normal shell'

登录后复制

变成

# echo 'This is a root shell'

登录后复制

在某些系统(如 Ubuntu)上,root 用户默认被锁定。(备注:搬瓦工并不会锁定,但是腾讯云默认会锁定)。

什么是 Sudo?

sudo (superuser do) 命令是一个命令行实用程序,它允许用户以 root 或其他用户身份执行命令。它提供了一种有效的方式来授予某些用户适当的权限以使用特定的系统命令或以 root 用户身份运行脚本。

虽然有点类似于 su 命令,但 sudo 的不同之处在于它默认需要用户的密码进行身份验证,而不是 su 需要的目标用户的密码。Sudo 也不会产生 root shell;相反,它以提升的权限运行程序或命令,不像 su,它产生一个 root shell。

使用 sudo,系统管理员可以执行以下操作:

授予用户或用户组以提升或 root 权限运行某些命令的能力。查看每个使用 sudo 的用户的用户 ID 的日志。控制用户可以在主机系统上使用什么命令。

Sudo 会记录在 /var/log/auth.log 文件中执行的所有命令和参数的日志,可以在出现故障时进行分析。

sudoers 文件

sudo 使用默认的 sudoers 安全策略,并保留一个特殊的配置文件 /etc/sudoers。该文件可用于控制访问权限和密码提示超时。

注意:您必须具有提升的权限才能查看 sudoers 文件

打开 /etc/sudoers 文件;它应该是这样的:

# This file MUST be edited with the 'visudo' command as root.## Please consider adding local content in /etc/sudoers.d/ instead of# directly modifying this file.## See the man page for details on how to write a sudoers file.#Defaults        env_resetDefaults        mail_badpassDefaults        secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"# Host alias specification# User alias specification# Cmnd alias specification# User privilege specificationroot    ALL=(ALL:ALL) ALL# Allow members of group sudo to execute any command%sudo   ALL=(ALL:ALL) ALL# See sudoers(5) for more information on "@include" directives:@includedir /etc/sudoers.d

登录后复制

其中这行:

root         ALL=(ALL:ALL)ALL

登录后复制

意味着 root 用户拥有无限的权限并且能够在系统上运行任何命令。

%sudo ALL=(ALL:ALL)ALL

登录后复制

允许组 sudo 的所有成员执行任何命令。

注意:sudoers 文件中的 ‘%’ 代表一个组,而不是注释。

从 /etc/sudoers 文件的第一行可以看出:

# This file MUST be edited with the 'visudo' command as root

登录后复制

不要尝试直接编辑 sudoers 文件。使用具有 root 权限的 visudo 命令。

使用 sudo 运行命令很简单,只需要在命令前面加上 sudo 即可:

$ sudo command

登录后复制

一般来说会提示输入密码,输入密码后回车即可。

$ sudo command[sudo]  password for user:

登录后复制

Sudo 对比 Root

最小权限原则是一种信息和计算机安全概念,它认为授予程序和用户执行任务所需的最少或最低限度的权限。

以 root 用户登录后,输入到终端的每一条命令都以系统最高权限运行,违反了最小权限原则。像 rm 这样的简单命令可用于删除核心根目录或文件,而不会在意外时提示用户。例如,如果您尝试使用以下命令删除 /etc 之类的根目录:

$ rm -rf /etc

登录后复制

当您以普通用户身份登录时,您将被拒绝许可。当以 root 身份登录时,不会显示任何提示,并且整个文件夹将被删除 – 这很可能会破坏您的系统,因为运行系统所需的特殊配置文件存储在 /etc 目录中。您也可能最终错误地格式化磁盘,并且系统不会提示您。

此缺陷还扩展到以 root 身份运行代码或应用程序;应用程序中的一个小错误可能会删除一些系统文件,因为该应用程序是在最高权限下运行的。

Sudo 提供细粒度的访问控制。它仅向需要它的特定程序授予提升的权限。您知道哪个程序以提升的权限运行,而不是使用 root shell(以 root 权限运行每个命令)。

Sudo 也可以配置为以另一个用户身份运行命令,指定允许哪些用户和组使用 sudo 运行命令,或者通过编辑 sudoers 文件设置以 root 权限运行程序的超时。

因此,不建议使用 root shell 运行命令,因为您破坏系统的机会要高得多。如果您需要更高权限或 root 权限来运行命令,请使用 sudo 确保只有该命令以 root 权限运行。

以上就是Linux 中 root 与 sudo 的用法与区别,居然这么多人搞不清楚!的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2204213.html

(0)
上一篇 2025年2月26日 00:55:59
下一篇 2025年2月26日 00:56:15

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • pycharm怎样改字体大小

    在PyCharm中,更改字体大小只需几个步骤:打开字体设置(文件>设置>编辑器>字体/PyCharm>首选项>编辑器>字体);选择字体;输入所需大小;预览更改;应用更改。 PyCharm中如何更改字体大小…

    2025年2月26日
    000
  • 怎样把pycharm变成白色的主题

    可以,PyCharm 提供多种浅色主题,以下是如何更改:1. 打开“Preferences”对话框。2. 导航到“Appearance & Behavior”设置。3. 展开“Theme”下拉菜单,选择 浅色 主题,如 Defaul…

    2025年2月26日
    200
  • pycharm怎样设置中文

    PyCharm 可通过以下步骤设置中文语言:1. 打开设置,选择“外观与行为”>“外观”。2. 在“语言和字体”下拉列表中选择“中文(简体)”。3. 重启 PyCharm 以应用更改。此后,PyCharm 界面和文档均将显示为中文。 …

    2025年2月26日
    200
  • pycharm怎样打开一个新的项目

    在 PyCharm 中打开新项目的方法:启动 PyCharm 并通过欢迎屏幕或“Open”选项打开项目所在文件夹。选择要与项目关联的 Python 解释器(可选)。单击“OK”按钮打开项目。 如何在 PyCharm 中打开新项目 PyCha…

    2025年2月26日
    200
  • pycharm怎样保存文件

    PyCharm 提供了四种文件保存方法:通过文件菜单、快捷键、工具栏按钮或启用自动保存。您还可以将文件保存为模板,并保存各种文件类型。 如何保存 PyCharm 中的文件 PyCharm 是一款功能强大的 Python IDE,为开发人员提…

    2025年2月26日
    100
  • pycharm怎样新建txt

    PyCharm创建txt文件步骤:打开项目资源管理器,右键单击文件夹,选择“新建”>“文件”。输入文件名称,确保扩展名为“.txt”。单击“确定”创建文件。保存文件:按Ctrl+S(Windows/Linux)或Cmd+S(macOS…

    2025年2月26日
    200
  • python软件下载

    Python 的官方下载方式为访问 Python 官方网站并根据操作系统下载对应版本。其他下载选项包括 PyPI 和第三方存储库,可能提供附加功能或预先安装的库。 Python 软件下载指南 如何下载 Python 下载 Python 的官…

    2025年2月26日
    200
  • python代码复制快捷键

    Python 快捷键:复制当前行:Windows/Linux:Ctrl + C;macOS:Cmd + C复制多行:按住 Shift 键,选择行,按 Ctrl + C (Windows/Linux) 或 Cmd + C (macOS)粘贴代…

    2025年2月26日
    200
  • 怎么用pycharm打开一个py文件

    如何在 PyCharm 中打开 .py 文件:打开 PyCharm;选择「文件」->「打开」,浏览并选择 .py 文件,单击「打开」;.py 文件将在编辑器区域中打开。还可通过拖放或使用快捷键 Ctrl+O (Windows/Linu…

    2025年2月26日
    200
  • pycharm环境配置错误怎么改正

    解决PyCharm环境配置错误的步骤:检查Python解释器路径是否正确配置。安装必要的Python库。检查环境变量中是否包含Python解释器和库路径。重新加载项目以应用更改。更新PyCharm至最新版本。如果以上方法无效,重置PyCha…

    2025年2月26日
    200

发表回复

登录后才能评论