0

0

Linux capabilities 的最小权限原则与 setcap/getcap 命令使用规范

舞姬之光

舞姬之光

发布时间:2026-02-21 11:51:11

|

912人浏览过

|

来源于php中文网

原创

linux capabilities 通过精细化拆分 root 权限实现最小权限原则,应仅授予程序必需的单个能力(如 cap_net_bind_service),避免使用 cap_sys_admin 等全能型能力;setcap 须由 root 对静态可执行文件操作,禁用脚本、通配符和 setuid 位;getcap 用于审计,关注 +ep 标志;能力需与 dac、mac、namespace 等协同构成纵深防御。

linux capabilities 的最小权限原则与 setcap/getcap 命令使用规范

Linux capabilities 是对传统 root 权限的精细化拆分,遵循最小权限原则意味着:只赋予程序运行所必需的单个或少数几个 capability,而非直接给它 rootsudo 权限。配合 setcapgetcap 命令,可安全地为二进制文件绑定特定能力,避免提权风险。

最小权限原则的核心实践

不把 CAP_SYS_ADMINCAP_NET_ADMIN 等“全能型” capability 当成默认选项。例如:

  • 只需绑定端口 80?用 CAP_NET_BIND_SERVICE 即可,无需 root
  • 只需修改系统时间?授予 CAP_SYS_TIME,而非整个 CAP_SYS_ADMIN
  • 需挂载文件系统?优先考虑是否可通过 systemd mount unit 或用户命名空间替代,实在需要再赋 CAP_SYS_ADMIN,并严格限制执行路径和参数

setcap 命令的安全使用规范

setcap 必须由 root 执行,且仅作用于**静态链接的可执行文件**(不能是脚本、shell 封装器或解释器如 python)。常见误操作包括:

通塔师AI导航
通塔师AI导航

通塔师AI导航:专业的AI人工智能工具软件导航网站

下载
  • 对脚本设 capability —— 实际无效,内核只检查解释器本身的能力,而解释器通常无权加载脚本能力
  • 设了 capability 却未去掉 setuid 位 —— 能力会被忽略,应先 chmod u-s
  • 用通配符或宽泛路径赋权(如 /usr/bin/*)—— 易误伤,应精确到具体二进制文件,如 /usr/local/bin/myserver
  • 使用 =ep 后缀时未验证继承行为 —— ep 表示 effective + permitted,子进程默认不会继承,如需继承需额外设置 ambient 或用 capsh 调试

getcap 命令的日常检查要点

getcap 是审计 capability 配置的首选工具,建议定期扫描关键路径:

  • 查单个文件:getcap /usr/bin/ping → 输出 /usr/bin/ping = cap_net_raw+ep
  • 递归查敏感目录:getcap -r /usr/bin 2>/dev/null | grep -v "No such file"
  • 识别异常能力组合:getcap -r /usr 2>/dev/null | grep "cap_sys_admin\|cap_dac_override"
  • 注意输出中的 +eip 含义:e=effective, i=inheritable, p=permitted;生产环境一般只需 +ep,避免不必要的 i

能力管理的补充注意事项

capability 不是万能补丁,需结合其他机制形成纵深防御:

  • Capability 无法绕过 DAC(文件权限)、MAC(SELinux/AppArmor)或 namespace 限制
  • 容器中(如 Docker)默认丢弃多数 capability,启用需显式加 --cap-add,且应禁用 --privileged
  • 升级软件包后,重装可能覆盖原有 capability 设置,建议将 setcap 步骤纳入部署脚本并做幂等校验
  • 调试时可用 capsh --print 查看当前 shell 的 capability 集合,或 cat /proc/$PID/status | grep Cap 查进程实际生效能力

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

13

2026.02.03

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

246

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

806

2024.03.01

k8s和docker区别
k8s和docker区别

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

265

2023.07.24

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

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

512

2024.04.08

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

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

411

2024.04.08

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

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

447

2024.04.08

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.4万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

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

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