AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 441151
Accepted
Tim
Tim
Asked: 2018-05-02 11:52:04 +0800 CST2018-05-02 11:52:04 +0800 CST 2018-05-02 11:52:04 +0800 CST

`sudo` 要求输入哪个用户的密码?

  • 772
$ ls -l /usr/bin/sudo
-rwsr-xr-x 1 root root 136808 Jul  4  2017 /usr/bin/sudo

sosudo可由任何用户运行,并且任何运行的用户都sudo将 root 作为进程的有效用户 ID,因为设置了 set-user-id 位/usr/bin/sudo。

来自https://unix.stackexchange.com/a/11287/674

sudo 和 su 之间最明显的区别是sudo 需要用户的密码,而 su 需要 root 的密码。

  1. 需要哪个用户的密码sudo?是进程的真实用户ID所代表的用户吗?

    如果是,是否任何用户都可以通过运行sudo然后提供自己的密码来获得超级用户权限?Linux可以限制某些用户吗?

  2. 开始执行后询问sudo密码是否正确? execve()main()/usr/bin/sudo

    既然进程的euid已经改成root了(因为设置了/usr/bin/sudo的set-user-id位),以后sudo要密码又有什么意义呢?

谢谢。

我已阅读https://unix.stackexchange.com/a/80350/674,但它没有回答上述问题。

sudo executable
  • 4 4 个回答
  • 8569 Views

4 个回答

  • Voted
  1. Best Answer
    Stephen Kitt
    2018-05-02T13:10:59+08:002018-05-02T13:10:59+08:00
    1. 在其最常见的配置中,sudo要求输入运行 sudo用户的密码(如您所说,该用户对应于进程的真实用户 ID)。的重点sudo是授予特定用户额外的权限(由 中的配置确定sudoers),而这些用户无需提供除他们自己之外的任何其他身份验证。但是,sudo 确实会检查运行的用户是否sudo真的是他们声称的身份,并且它通过询问他们的密码(或为 设置的任何身份验证机制sudo,通常使用 PAM 来做到这一点 - 所以这可能涉及指纹或两个因素认证等)。

      sudo不一定授予成为root的权利,它可以授予各种特权。任何被允许成为 root 的用户sudoers都可以只使用他们自己的身份验证来做到这一点;但是用户不允许,不能(至少,不能使用sudo)。这不是由 Linux 本身强制执行的,而是由sudo(及其身份验证设置)强制执行的。

    2. sudo确实在它开始运行后要求输入密码;它不能做其他事情(即在它开始运行之前它不能做任何事情)。询问密码的sudo目的,即使它是 root,也是为了验证运行用户的身份(在其典型配置中)。

    • 23
  2. ilkkachu
    2018-05-02T13:22:09+08:002018-05-02T13:22:09+08:00

    sudo通常会询问运行它的用户的密码,尽管可以配置:

    与 不同su(1)的是,当 sudoers需要身份验证时,它会验证调用用户的凭据,而不是目标用户(或根用户)的凭据。这可以通过rootpw,targetpw和runaspw标志进行更改,稍后将介绍。

    设置rootpw一直sudo要求输入root的密码,targetpw要求输入用户的密码,sudo最终将程序运行为as,并runaspw要求输入用户的密码runas_default。

    这样的sudo二进制设置确实可以由任何用户以 root 权限启动。假设sudo其身份验证代码没有任何错误,这本身并不重要。

    有点类似,任何进程也可以在内核模式下执行代码,方法是调用任何系统调用,比如open(). (这与 root 的用户空间代码不同。)只要内核没有错误,它们就无法运行任意代码。

    • 13
  3. user232326
    2018-05-02T14:08:34+08:002018-05-02T14:08:34+08:00

    从 的第一行开始man sudo:

    描述
    sudo 允许允许的用户以超级用户或其他用户的身份执行命令,如安全策略所指定。调用用户的真实(无效)用户 ID 用于确定用于查询安全策略的用户名。

    所以:

    1. 使用调用用户的真实(无效)用户 ID ...
    2. 是的,任何(允许的)用户都可以通过运行 sudo 然后提供所需的(配置的)身份验证来获得超级用户(或其他)额外权限。允许和配置都在 sudoers 文件中设置。

    3. Linux可以限制某些用户吗?
      是的,它可以,但它不能。Linux 设置为允许 sudo 二进制文件根据 sudo 程序和文件内部的一组规则(安全策略)做出决定/etc/sudoers。通常,可以使用其他文件(也/代替)。

    来自man setresuid:

    描述
    setresuid() 设置调用进程的真实用户ID、有效用户ID和保存的set-user-ID。

    1. 获得内核授予的超级用户权限的唯一方法是运行程序 suid。否则不能。这是 Linux 选择授予超级用户权限的方式。

    2. 在内核加载了一个不能被任何其他用户修改的可执行文件(文件和目录由 root 拥有并且只能由 root 写入)之后,可执行文件本身(sudo)通过询问用户的密码(或配置的其他内容)来验证用户并决定是否授予以及授予哪些权限。

    • 8
  4. Stephen R
    2018-05-04T08:31:13+08:002018-05-04T08:31:13+08:00

    除了其他关于sudo:

    su让您有效地成为不同的用户。在我自己的计算机上,我不会以管理员身份运行日常使用——这意味着,除其他外,我不能(直接)使用sudo. 如果我确实想使用sudo,我可以使用su“成为”管理员用户,然后在该角色中使用sudo. 在那种情况下,我最终输入了两次管理员帐户的密码——一次是在我运行时su,一次是在我运行时sudo。

    • 0

相关问题

  • 'zfs send' 是安全的只读命令吗?

  • sudo nautilus 和 sudo -E nautilus 的区别

  • 更改可能缺少 shebang 的文件的默认可执行文件

  • 以其他用户身份运行单个命令;sudo 的限制

  • 允许用户以 root 身份运行命令

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve