土法炼钢兴趣小组的算法知识备份

【操作系统百科】SELinux 与 AppArmor

文章导航

分类入口
os
标签入口
#selinux#apparmor#lsm#mac#mandatory-access-control

目录

DAC(自主访问控制)只看 UID/GID → 一旦进程被入侵就拥有该用户的全部权限。MAC(强制访问控制)在 DAC 之上加一层强制策略。

一、先看图

flowchart TD
    SYSCALL[系统调用] --> DAC[DAC 检查<br/>UID/GID/权限位]
    DAC --> LSM{LSM hooks}
    LSM --> SE[SELinux<br/>类型强制]
    LSM --> AA[AppArmor<br/>路径强制]
    LSM --> OTHER[其他 LSM<br/>SMACK/TOMOYO]
    SE --> ALLOW[允许 / 拒绝]
    AA --> ALLOW

    classDef dac fill:#f0883e22,stroke:#f0883e,color:#adbac7;
    classDef mac fill:#388bfd22,stroke:#388bfd,color:#adbac7;
    class SYSCALL,DAC dac
    class LSM,SE,AA,OTHER,ALLOW mac

二、LSM 框架

Linux Security Modules → 内核在关键操作前调用安全钩子:

// security/security.c
int security_file_open(struct file *file)
{
    return call_int_hook(file_open, file);
}

多个 LSM 可以堆叠(SELinux + Landlock + BPF_LSM)。

三、SELinux

3.1 类型强制(Type Enforcement)

每个进程有类型(domain),每个文件有类型:

httpd_t → 读 httpd_sys_content_t  ✓
httpd_t → 读 shadow_t             ✗

3.2 策略语言

allow httpd_t httpd_sys_content_t:file { read open getattr };

3.3 模式

getenforce          # Enforcing / Permissive / Disabled
setenforce 0        # 临时切换到 Permissive
# /etc/selinux/config 永久配置

3.4 容器标签

# 每个容器自动分配 MCS 标签
docker run → svirt_lxc_net_t:s0:c123,c456

不同容器的标签不同 → 互相隔离。

四、AppArmor

4.1 路径基础

AppArmor 用文件路径(不是 inode 标签):

profile /usr/bin/nginx {
    /var/www/** r,
    /var/log/nginx/** w,
    /etc/nginx/** r,
    network tcp,
}

4.2 优势与劣势

方面 SELinux AppArmor
模型 类型标签 路径
粒度 更细 较粗
复杂度
默认发行版 RHEL/Fedora Ubuntu/SUSE
重命名文件 标签跟随 inode 路径变化可能失效

五、audit 日志

# SELinux 拒绝日志
ausearch -m avc -ts recent
# type=AVC msg=audit(...): avc: denied { read } for pid=1234
#   scontext=httpd_t tcontext=shadow_t tclass=file

# AppArmor 拒绝日志
dmesg | grep "apparmor=\"DENIED\""

六、编写策略

6.1 SELinux

# 从拒绝日志生成策略
ausearch -m avc | audit2allow -M mypolicy
semodule -i mypolicy.pp

6.2 AppArmor

# 学习模式
aa-complain /usr/bin/nginx
# 运行程序 → 记录访问
aa-logprof                   # 从日志生成策略
aa-enforce /usr/bin/nginx    # 切换到强制模式

七、BPF_LSM

SEC("lsm/file_open")
int BPF_PROG(my_lsm, struct file *file)
{
    // 动态安全策略
    if (should_deny(file))
        return -EPERM;
    return 0;
}

可编程的 LSM → 不需要写内核模块。

八、多 LSM 堆叠

Linux 5.1+ 支持 LSM 堆叠:

cat /sys/kernel/security/lsm
# lockdown,capability,landlock,yama,apparmor,bpf

九、观察

# 当前 LSM
cat /sys/kernel/security/lsm

# SELinux
getenforce
sestatus
seinfo -t | wc -l      # 类型数量

# AppArmor
aa-status
cat /sys/kernel/security/apparmor/profiles

十、小结


参考文献

工具


上一篇seccomp 下一篇完整性验证

同主题继续阅读

把当前热点继续串成多页阅读,而不是停在单篇消费。

2026-05-06 · os

【操作系统百科】内核内存调试

内核内存 bug 是最难追的:UAF、OOB、double free、leak 都可能沉默数月。本文讲 KASAN 三种模式、KFENCE 生产采样、kmemleak、SLUB_DEBUG、UBSAN/KCSAN 联动。

2026-05-08 · os

【操作系统百科】VFS 四层抽象

Linux 的一切皆文件靠 VFS 实现——superblock、inode、dentry、file 四层抽象加 ops 表。本文讲 VFS 核心数据结构、dcache、inode cache、RCU lookup,以及文件系统如何插入 VFS。

2026-04-22 · os

操作系统百科

Linux 6.x 视角下的操作系统系列索引:110 篇覆盖调度、虚拟内存、文件系统与 I/O、并发、隔离、可观测性,按主题、阅读路径与关键问题三种入口组织。


By .