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 / 问题 / 792302
Accepted
aluriak
aluriak
Asked: 2025-03-12 00:38:26 +0800 CST2025-03-12 00:38:26 +0800 CST 2025-03-12 00:38:26 +0800 CST

获取通过链接 su 调用创建的用户链

  • 772

在管理 Linux 服务器(例如 Debian 服务器)时,我经常切换用户。有时,我会将多个用户切换串联在一起:

aluriak$ sudo -s
root$ […]
root$ su aluriak
aluriak$ […]
aluriak$ su db
db$ […]
db$ <ctrl-D>
aluriak$ su front
front$ […]

有什么方法可以让我获取通过这种方式创建的“用户链”吗?

在上面的例子中,该假设的实用程序将输出类似的内容front aluriak root aluriak,因为我是前端用户,从 aluriak 用户登录,他自己从 root 帐户登录,而他本身是从 aluriak 帐户访问的。

command-line
  • 4 4 个回答
  • 571 Views

4 个回答

  • Voted
  1. Best Answer
    Andrew Henle
    2025-03-12T19:18:13+08:002025-03-12T19:18:13+08:00

    假设你只想要当前活动的进程链,你也可以使用pstree -s -u $$

    来自手册pstree页:

       -s     Show parent processes of the specified process.
    

    这将列出父进程——正是这里所需要的。

       -u     Show uid transitions.  Whenever the uid of a process
              differs from the uid of its parent, the new uid is shown in
              parentheses after the process name.
    

    再次强调——这正是我们想要的。

    pstree -s -u $$Ubuntu 22 系统上的示例输出:

    systemd───systemd(ahenle)───gnome-terminal-───bash───pstree
    

    请注意,新用户名列在进程名称后的括号中,而不是手册页所述的 UID。在 Centos 7 和 RHEL 9 实例上进行的快速测试显示了相同的行为 - 发出的是用户名而不是 UID。

    如果需要,您可以添加-p添加 pid 的选项。

       -p     Show PIDs.  PIDs are shown as decimal numbers in
              parentheses after each process name.  -p implicitly
              disables compaction.
    

    pstree -p -s -u $$同样是在 Ubuntu 22 系统上的示例输出:

    systemd(1)───systemd(4651,ahenle)───gnome-terminal-(824170)───bash(824177)───pstree(3825436)
    
    • 8
  2. aluriak
    2025-03-12T00:38:26+08:002025-03-12T00:38:26+08:00

    一个解决方案是查看系统的身份验证日志,例如/var/log/auth.log,获取如下行:

    su: (to aluriak) root on pts/1
    su: (to root) aluriak on pts/1
    su: (to db) root on pts/1
    su: pam_unix(su:session): session closed for user db
    su: pam_unix(su:session): session closed for user root
    su: pam_unix(su:session): session closed for user aluriak
    

    由于日志按时间排序,因此可以追溯登录/注销操作,并列出每个步骤。信息pts/1提供了会话编号,以避免混淆两个会话。您可以使用 获取您的会话tty。

    • 3
  3. ron
    2025-03-12T01:30:50+08:002025-03-12T01:30:50+08:00

    除非您已完成,否则答案是可追溯的。它将在项目的和字段中显而易见。/var/log/audit/audit.logsystemctl disable | stop> auditdUIDAUIDexe=/usr/bin/su

    以及/var/log/secure{在 RHEL 8 中} 的su:session行

    • 3
  4. Toby Speight
    2025-03-12T16:57:10+08:002025-03-12T16:57:10+08:00

    因为这是 Linux,所以您有一个/proc文件系统。如果您有权访问其他进程的条目(通常,如果您成为 root 用户),那么您可以检查SUDO_*每个祖先进程环境中的变量。

    这些变量由以下方式设置sudo:

    • SUDO_COMMAND
    • SUDO_GID
    • SUDO_HOME
    • SUDO_UID
    • SUDO_USER

    我们感兴趣的是SUDO_USER。

    因此,我们只需要检查父进程链以找到SUDO_USER更改值的位置。然后反转结果以tac显示当前用户最后:

    #!/bin/sh
    
    set -eu
    
    pid=$$
    while pid=$(ps -o ppid= -p $pid) && [ -r "/proc/$pid/environ" ]
    do tr '\0' '\n' <"/proc/$pid/environ" | sed -n 's/^SUDO_USER=//p'
    done | uniq | tac
    
    • 2

相关问题

  • ip 命令是否支持通配符?

  • 需要许多参数的实用程序的推荐界面是什么?[关闭]

  • 远程运行 X 应用程序,在远程主机上运行 GUI [关闭]

  • 使 mysql CLI 以交互方式向我询问密码

  • 没有服务器的命令行 pub/sub?

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

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

    • 4 个回答
  • Marko Smith

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

    • 5 个回答
  • Marko Smith

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

    • 3 个回答
  • 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
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +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

热门标签

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