0

0

Linux如何禁止普通用户查看系统进程 proc权限控制方法

P粉602998670

P粉602998670

发布时间:2025-08-02 15:16:01

|

463人浏览过

|

来源于php中文网

原创

要限制linux用户查看其他用户的进程,可通过调整/proc的挂载参数实现;1. /proc是虚拟文件系统,默认所有用户可查看所有进程信息;2. 使用hidepid参数可控制进程可见性,hidepid=1隐藏其他用户进程,hidepid=2进一步隐藏自身进程部分信息;3. 可结合gid=指定特定组用户拥有完整访问权限;4. 对于更高级隔离,可使用容器或pam模块配置pid命名空间;5. 修改前需谨慎测试,考虑selinux/apparmor策略及远程登录安全性。

Linux如何禁止普通用户查看系统进程 proc权限控制方法

在Linux系统中,默认情况下普通用户可以通过

/proc
文件系统查看进程信息,包括其他用户的进程。如果你希望限制某些用户只能看到自己的进程,或者完全禁止他们查看系统进程,就需要调整
/proc
的权限设置。

Linux如何禁止普通用户查看系统进程 proc权限控制方法

1.
/proc
目录的作用与默认权限

/proc
是一个虚拟文件系统,它提供了内核和进程运行状态的信息。每个进程在
/proc/[pid]
下都有一个对应的目录。默认情况下,所有用户都可以列出这些目录并查看部分信息。

Linux如何禁止普通用户查看系统进程 proc权限控制方法

例如,运行

ps aux
或直接访问
/proc/[pid]/status
时,普通用户也能看到其他用户的进程详情。这可能带来一定的安全风险,特别是在多用户环境下。

关键点:

Linux如何禁止普通用户查看系统进程 proc权限控制方法
  • /proc
    是动态生成的,不能直接修改权限来完全阻止访问。
  • 可以通过挂载选项或使用命名空间(如容器)来实现更细粒度的控制。

2. 使用
hidepid
参数限制进程可见性

Linux提供了一个非常实用的机制:在挂载

/proc
时使用
hidepid
参数,可以限制用户对进程信息的访问。

修改方法:

编辑

/etc/fstab
文件,找到类似如下行:

proc /proc proc defaults 0 0

然后添加

hidepid
参数,比如改为:

HeyGen
HeyGen

HeyGen是一个AI虚拟数字人生成平台,可以根据用户提供的内容,快速生成高质量的虚拟发言人视频,支持数字化身、文本转视频和视频翻译。

下载
proc /proc proc defaults,hidepid=2 0 0
注意: 修改后需要重新挂载/proc,或重启系统生效。

参数说明:

  • hidepid=0
    :默认行为,所有人都能看到所有进程。
  • hidepid=1
    :用户看不到其他用户的进程。
  • hidepid=2
    :不仅看不到其他人的进程,连自己进程的部分信息也被隐藏。
  • hidepid=4
    :启用审计日志记录,配合
    subset=pid
    使用。

此外还可以结合

gid=
选项指定某个组的用户可以查看全部进程:

proc /proc proc defaults,hidepid=2,gid=admin 0 0

这样只有属于

admin
组的用户才能完整访问
/proc
内容。

3. 配合PAM和命名空间实现更高级的隔离

对于更严格的场景,比如服务器上运行了多个非信任用户的服务,可以考虑使用容器技术(如Docker、LXC)或通过PAM模块配置会话环境,为每个用户创建独立的PID命名空间。

在这种环境中,用户只能看到自己的进程,根本无法接触到系统级的进程列表。这种方法更彻底,但也更复杂,适合有运维基础的人员使用。

适用情况:

  • 多租户服务器
  • 教学或开发用共享主机
  • 安全要求较高的生产环境

4. 注意事项与常见问题

  • 权限修改需谨慎:误操作可能导致系统命令(如
    top
    ps
    )无法正常工作。
  • 测试环境优先:建议先在测试机器上验证效果,避免影响线上服务。
  • SELinux/AppArmor:如果启用了安全模块,还需检查策略是否允许相关访问。
  • 远程登录用户:即使设置了
    hidepid
    ,也要确保SSH等服务不会暴露额外信息。

基本上就这些方法了。通过

hidepid
是最直接有效的控制手段,而容器隔离则是更现代也更干净的做法。不复杂但容易忽略的是,权限控制往往不只是改一个参数那么简单,还要综合考虑整个系统的安全策略。

相关专题

更多
k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

249

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

494

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

398

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

436

2024.04.08

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1348

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

701

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

3

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号