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 木马清除方法

