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

发布时间 - 2025-08-02 00:00:00    点击率:

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

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

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

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

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

例如,运行

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

关键点:

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

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

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

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

修改方法:

编辑

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

proc /proc proc defaults 0 0

然后添加

hidepid
参数,比如改为:

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


# linux  # docker  # 命名空间  # ssh  # 自己的  # 文件系统  # 可以通过  # 普通用户  # 也更  # 的是  # 是一个  # 情况下  # 需谨慎  # 如果你 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  html如何与html链接_实现多个HTML页面互相链接【互相】  如何快速生成凡客建站的专业级图册?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  如何在腾讯云服务器快速搭建个人网站?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  Android okhttputils现在进度显示实例代码  Laravel怎么上传文件_Laravel图片上传及存储配置  Android利用动画实现背景逐渐变暗  如何快速搭建安全的FTP站点?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  详解阿里云nginx服务器多站点的配置  网页设计与网站制作内容,怎样注册网站?  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  深入理解Android中的xmlns:tools属性  个人网站制作流程图片大全,个人网站如何注销?  简历在线制作网站免费版,如何创建个人简历?  js实现点击每个li节点,都弹出其文本值及修改  如何在万网ECS上快速搭建专属网站?  Internet Explorer官网直接进入 IE浏览器在线体验版网址  如何基于PHP生成高效IDC网络公司建站源码?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  北京专业网站制作设计师招聘,北京白云观官方网站?  Windows10如何更改计算机工作组_Win10系统属性修改Workgroup  Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】  香港服务器网站推广:SEO优化与外贸独立站搭建策略  黑客入侵网站服务器的常见手法有哪些?  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  香港服务器如何优化才能显著提升网站加载速度?  如何在VPS电脑上快速搭建网站?  Laravel如何处理异常和错误?(Handler示例)  如何在橙子建站中快速调整背景颜色?  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  iOS验证手机号的正则表达式  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在阿里云高效完成企业建站全流程?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  如何获取PHP WAP自助建站系统源码?  js代码实现下拉菜单【推荐】  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  Linux系统命令中tree命令详解  如何在阿里云域名上完成建站全流程?  如何用5美元大硬盘VPS安全高效搭建个人网站?  linux top下的 minerd 木马清除方法