深入理解Linux Capability

在Linux中,每个进程都有一组权限限制其可访问和执行的资源。这些权限通过内核安全模型(如SELinux)实现,并包含基本UNIX权限(rwx),UID、GID和特殊权限。但是,这些基本权限并不足以精细控制进程所能访问的资源。在Linux 2.2中引入了Capability概念,为了增强进程可访问的资源的控制,Capability技术横空出世。

一、什么是Capability

Capability是一种格外授权机制,通过设置特定的Capability来精细控制进程所能访问的资源。同样,该机制可以将某些超级用户能力下放到非特权进程或二进制文件中,从而减少了系统对root的依赖,防止被黑客攻击。

每个Capability可以控制进程中的某种资源(如CAP_SYS_ADMIN控制文件系统操作),让用户细粒度地控制资源。同时,Capability能方便将某些特权操作,像访问某些硬件,变成普通用户所能访问的操作。

二、如何使用Capability

1. 常见的Capability操作

Capability的使用涉及一下常见的操作:

  1. 通过命令行临时设置某个Capability并启动进程:
    $ sudo setcap cap_net_admin=eip /usr/bin/ping
    $ ping www.baidu.com
  2. 让二进制文件以某个Capability启动:
    $ sudo setcap 'cap_net_admin=eip' /usr/bin/ping
    $ ./ping www.baidu.com
  3. 二进制文件作为服务运行,通过systemd单元设置Capability:
    [Unit]
    Description=Ping server
    
    [Service]
    ExecStart=/path/to/ping-server
    AmbientCapabilities=CAP_NET_ADMIN
    
    [Install]
    WantedBy=multi-user.target

2. 如何查看当前进程的Capabilities

一个进程的Capability可以通过/proc/pid/status文件查看:

CapInh:\t00000000a80425fb
CapPrm:\t00000000a80425fb
CapEff:\t00000000a80425fb
CapBnd:\t00000000a80425fb
CapAmb:\t0000000000000000

上面的代码分别表示:

  • CapInh:指定进程的Inheritable Capability集合(该进程从其父进程继承的)。
  • CapPrm:指定进程的Permitted Capability集合(该进程能够获取的)。
  • CapEff:指定进程的 Effective Capability 集合(该进程当前拥有的)。
  • CapBnd:指定进程的Capability 境界集合(该进程不能超过的Capability)。
  • CapAmb:指定进程的Ambient Capability集合(该进程在进程启动时拥有的Capability集合)。

3. 代码设置Capability

通过代码设置Capability也是可以的。在使用Capabilty时要添加头文件:

#include <linux/capability.h>

int main(int argc, char *argv[]) {
  //申请capability
  cap_t caps = cap_from_text("CAP_NET_ADMIN+eip CAP_NET_RAW");
  //设置capability
  cap_set_proc(caps);
  //打印capability
  printf("Effective CAP: %d\n", cap_get_pid(getpid())->version);
  //释放capablity资源
  cap_free(caps);
}

三、常用Capability

下面列举了Linux下常用的Capability:

Capability Description 例子
CAP_AUDIT_CONTROL 启动和停止审计记录,更改审计过滤器和配置。 auditd
CAP_SYS_ADMIN 最高权限,绕过所有内核安全机制,包括SELinux和AppArmor。 mount, umount, pivot_root
CAP_NET_ADMIN 配置网络接口,修改主机名,使用raw sockets等 ifconfig, route, ping
CAP_IPC_LOCK 能锁住(protect)部分进程的内存区域,防止进程内存被其他进程篡改。 mlock
CAP_SYS_PTRACE PTRACE_ATTACH和PTRACE_KILL的权限,也即执行跟踪其他进程的权限 strace, gdb

四、总结

本文介绍了Linux下的Capability,它是Linux从基本权限概念上衍生出来的格外授权机制。它能为系统提供一个安全、轻便的授权机制,从而能让进程只是需要必要权限,而非具有root用户的所有权限。了解并掌握Capability是Linux安全管理的重要一部分。

原创文章,作者:PBTUZ,如若转载,请注明出处:https://www.506064.com/n/332253.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
PBTUZPBTUZ
上一篇 2025-01-21 17:30
下一篇 2025-01-21 17:30

相关推荐

  • 如何在Linux中添加用户并修改配置文件

    本文将从多个方面详细介绍在Linux系统下如何添加新用户并修改配置文件 一、添加新用户 在Linux系统下创建新用户非常简单,只需使用adduser命令即可。使用以下命令添加新用户…

    编程 2025-04-27
  • 如何解决linux jar包 invalid or corrupt jarfile问题

    对于许多开发人员和系统管理员在Linux环境下使用Java开发过程中遇到的一个常见的问题是 invalid or corrupt jarfile(无效或损坏的jar文件)错误。当您…

    编程 2025-04-27
  • 在Linux上安装JRE并配置环境变量

    本文将从以下几个方面为您详细阐述如何在Linux系统上,通过自己账户安装JRE,并且配置环境变量。 一、安装JRE 在进行安装前,我们需要下载JRE的安装包并解压,可以从官方网站下…

    编程 2025-04-27
  • GTKAM:Linux下的照片管理器

    GTKAM是用于Linux操作系统的一款照片管理器,它支持多种相机及存储设备,并提供了一系列强大的工具,让用户可以方便地浏览、管理、编辑和导出照片。本文将从多个方面对GTKAM进行…

    编程 2025-04-27
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • 深入解析Vue3 defineExpose

    Vue 3在开发过程中引入了新的API `defineExpose`。在以前的版本中,我们经常使用 `$attrs` 和` $listeners` 实现父组件与子组件之间的通信,但…

    编程 2025-04-25
  • 深入理解byte转int

    一、字节与比特 在讨论byte转int之前,我们需要了解字节和比特的概念。字节是计算机存储单位的一种,通常表示8个比特(bit),即1字节=8比特。比特是计算机中最小的数据单位,是…

    编程 2025-04-25
  • 深入理解Flutter StreamBuilder

    一、什么是Flutter StreamBuilder? Flutter StreamBuilder是Flutter框架中的一个内置小部件,它可以监测数据流(Stream)中数据的变…

    编程 2025-04-25
  • 深入探讨OpenCV版本

    OpenCV是一个用于计算机视觉应用程序的开源库。它是由英特尔公司创建的,现已由Willow Garage管理。OpenCV旨在提供一个易于使用的计算机视觉和机器学习基础架构,以实…

    编程 2025-04-25

发表回复

登录后才能评论