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
    • 最新
    • 标签
主页 / ubuntu / 问题 / 13599
Accepted
poolie
poolie
Asked: 2010-11-17 17:51:50 +0800 CST2010-11-17 17:51:50 +0800 CST 2010-11-17 17:51:50 +0800 CST

如何对其他用户隐藏进程参数?

  • 772

不久前,我曾经使用grsecurity内核补丁,它可以选择对其他非 root 用户隐藏进程参数。基本上这只是/proc/*/cmdline模式 0600,并ps通过显示进程存在而不是其参数来正确处理。

如果有人在多用户机器上运行 say ,这很好vi christmas-presents.txt,使用规范示例。

除了安装新内核之外,在 Ubuntu 中是否有任何受支持的方法可以做到这一点?

(我熟悉让单个程序更改其 argv 的技术,但大多数程序不这样做,而且无论如何它是活泼的。 这个 stackoverflow 用户似乎在问同样的问题,但实际上似乎很困惑。)

security kernel
  • 5 5 个回答
  • 3018 Views

5 个回答

  • Voted
  1. Kees Cook
    2010-11-18T12:09:56+08:002010-11-18T12:09:56+08:00

    目前这样做的唯一方法是将每个用户放在一个单独的容器中(请参阅使用和克隆),并在容器中安装一个新用户。(lxc会为你做一些。)CLONE_NEWPIDCLONE_NEWNS/proc

    但是,有计划将 grsecurity 功能移植到 Ubuntu 和上游内核。如果可以的话,请注册一些东西并提供帮助。

    • 8
  2. Andy
    2010-11-18T11:31:40+08:002010-11-18T11:31:40+08:00

    在 Natty 之前(包括 Natty),无法/proc/$pid/cmdline使用股票内核更改文件的权限,权限位内置于内核中。目前,您必须构建一个应用了这些补丁的定制内核。

    如果补丁很容易启用此功能,那么可能值得将它们发布到 Ubuntu 内核团队列表 ( [email protected] ),我们可以考虑将它们包含在未来的版本中。

    • 6
  3. Best Answer
    poolie
    2012-01-14T12:22:39+08:002012-01-14T12:22:39+08:00

    现在有一个hidepid挂载选项procfs,可让您向其他用户隐藏参数,并可选择允许一个组查看所有进程:

    第一个挂载选项称为“hidepid”,它的值定义了我们希望非所有者可以使用多少有关进程的信息:

    hidepid=0(默认)表示旧行为 - 任何人都可以读取所有世界可读的 /proc/PID/* 文件。

    hidepid=1 意味着用户不能访问任何 /proc/PID/ 目录,而是他们自己的。cmdline、sched*、status 等敏感文件现在受到其他用户的保护。由于在 proc_pid_permission() 中完成的权限检查和文件的权限保持不变,因此期望特定文件模式的程序不会混淆。

    hidepid=2 意味着 hidepid=1 加上所有 /proc/PID/ 将对其他用户不可见。这并不意味着它隐藏了一个进程是否存在(它可以通过其他方式获知,例如通过kill -0 $PID),但它隐藏了进程的euid和egid。它使入侵者收集有关正在运行的进程的信息、某些守护程序是否以提升的权限运行、另一个用户是否运行某些敏感程序、其他用户是否运行任何程序等的任务复杂化。

    gid=XXX 定义了一个能够收集所有进程信息的组(如在 hidepid=0 模式下)。应该使用该组,而不是将非 root 用户放在 sudoers 文件或其他东西中。但是,不应将不应监视整个系统中的任务的不受信任的用户(如守护程序等)添加到组中。

    hidepid=1 或更高版本旨在限制对 procfs 文件的访问,这可能会泄露一些敏感的私人信息,例如精确的击键时间:

    http://www.openwall.com/lists/oss-security/2011/11/05/3

    hidepid=1/2 不会破坏监视用户空间工具。ps、top、pgrep 和 conky 优雅地处理 EPERM/ENOENT 并表现得好像当前用户是唯一运行进程的用户。pstree 显示包含“pstree”进程的进程子树。

    • 6
  4. user9899
    2011-01-31T02:31:59+08:002011-01-31T02:31:59+08:00

    几年前,我发布了以下两个内核补丁:

    • 简单的进程隐藏内核补丁
    • 2.6.24.x 的进程隐藏内核补丁 (http://www.iezzi.ch/archives/120)

    这两个补丁仍然适用于 kernel.org 的当前稳定的 vanilla 内核。如果你有兴趣,我可以发布当前的补丁。不要问我为什么从来没有人在上游内核中包含进程隐藏选项。

    警告:这些补丁完全隐藏了除 root 之外的其他用户的进程。

    • 1
  5. RolandiXor
    2010-11-17T18:43:46+08:002010-11-17T18:43:46+08:00

    您可以通过在用户和组设置中更改他们的权限来阻止他们访问系统监视器和顶部。我不确定这将是一个完整的解决方案,但它应该足以阻止大多数普通用户使用。

    • -2

相关问题

  • Ubuntu 是否支持与 SSD 一起使用的 TRIM 命令?

  • 使用 apt-get upgrade 时如何强制安装内核更新?

  • 如何从命令行仅安装安全更新?关于如何管理更新的一些提示

  • iptables 的图形用户界面?

  • 如何与无头服务器进行图形交互?

Sidebar

Stats

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

    如何安装 .run 文件?

    • 7 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    如何获得 CPU 温度?

    • 21 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Marko Smith

    如何使用命令行将用户添加为新的 sudoer?

    • 7 个回答
  • Marko Smith

    更改文件夹权限和所有权

    • 9 个回答
  • Marko Smith

    你如何重新启动Apache?

    • 13 个回答
  • Marko Smith

    如何卸载软件?

    • 11 个回答
  • Marko Smith

    如何删除 PPA?

    • 26 个回答
  • Martin Hope
    NES 如何启用或禁用服务? 2010-12-30 13:03:32 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    Olivier Lalonde 如何在结束 ssh 会话后保持进程运行? 2010-10-22 04:09:13 +0800 CST
  • Martin Hope
    David B 如何使用命令行将用户添加为新的 sudoer? 2010-10-16 04:02:45 +0800 CST
  • Martin Hope
    Hans 如何删除旧内核版本以清理启动菜单? 2010-08-21 19:37:01 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve