0

0

Linux AppArmor 的 aa-genprof / aa-logprof 交互式 profile 生成流程

冷炫風刃

冷炫風刃

发布时间:2026-02-23 08:00:20

|

149人浏览过

|

来源于php中文网

原创

aa-logprof卡在提示是因为日志无足够denied事件或未读取正确日志源;需检查dmesg/journalctl中的apparmor拒绝记录,必要时手动指定日志路径输入。

linux apparmor 的 aa-genprof / aa-logprof 交互式 profile 生成流程

aa-logprof 为什么卡在“Please enter ‘1’, ‘2’ or ‘?’”却没显示规则选项

这是最常见的阻塞点:日志里没捕获到足够多的访问事件,或者 aa-logprof 没读到正确的日志源。它默认只看 /var/log/audit/audit.log(需 auditd 运行)或 /var/log/syslog(需 AppArmor 日志已启用),但很多系统默认只往 journald 写。

  • 先确认 AppArmor 实际记录了拒绝事件:sudo dmesg | grep -i apparmorsudo journalctl --no-pager -t kernel | grep -i "apparmor.*DENIED"
  • 如果 journalctl 有 DENIED 日志但 aa-logprof 看不见,手动指定日志路径:sudo aa-logprof -f /dev/stdin,然后把 journal 日志重定向进去:sudo journalctl --no-pager -t kernel | grep -i "apparmor.*DENIED" | sudo aa-logprof -f /dev/stdin
  • 确保目标程序已用 aa-enforceaa-complain 加载过 profile(哪怕空 profile),否则内核不会记录策略冲突

aa-genprof 启动后程序直接退出,profile 文件为空

aa-genprof 本质是启动一个带 trace 的子进程,靠 ptrace 捕获系统调用。如果被测程序是 setuid、由 systemd 管理、或本身做了反调试(比如某些 Go 二进制),它就无法注入和跟踪。

  • 不要用 sudo aa-genprof /usr/bin/myapp 直接跑特权程序;改用普通用户身份启动,并确保 profile 路径写对:sudo aa-genprof -d /etc/apparmor.d/usr.bin.myapp /usr/bin/myapp
  • systemd 服务?先停掉服务:sudo systemctl stop myapp.service,再用 aa-genprof 手动拉起二进制(不走 systemd)
  • Go 程序常见问题:加 GODEBUG=asyncpreemptoff=1 环境变量降低调度干扰,或换用 aa-logprof 配合真实运行日志更可靠
  • 检查 /proc/sys/kernel/yama/ptrace_scope,值为 12 会阻止非子进程 trace,临时设为 0echo 0 | sudo tee /proc/sys/kernel/yama/ptrace_scope

生成的 profile 里出现大量 abstractions 和 include,能不能删

能删,但不建议盲目删。AppArmor 的 abstraction(如 abstraction/baseabstraction/nameservice)是预定义的通用权限集,删了可能让程序运行时因缺失必要权限而失败,尤其是 DNS 查询、动态库加载、信号处理等隐式行为。

ResearchFlow
ResearchFlow

专为学术研究和深度信息探索设计的AI学术研究工具

下载
  • 删之前先测试:注释掉某条 include <abstraction></abstraction>,用 sudo apparmor_parser -r /etc/apparmor.d/usr.bin.myapp 重载,再运行程序观察是否报新的 DENIED
  • 真正冗余的是未被触发的路径规则——比如 profile 里有 /tmp/** rw, 但程序从不读写 /tmp,这种可删;但 /etc/ssl/certs/** r, 很可能被 OpenSSL 隐式调用,删了 HTTPS 请求就失败
  • aa-unconfined 查看当前进程实际使用的 profile 和未匹配的访问:sudo aa-unconfined -v

profile 生效后程序报 “Permission denied” 但日志没新 DENIED 记录

说明不是 AppArmor 拒绝的,而是其他机制拦截了——最常见的是 SELinux(即使你只配了 AppArmor)、文件能力(file capabilities)、或 systemd 的 RestrictAddressFamilies= 等 sandbox 参数。

  • 先确认 AppArmor 确实在管这个进程:cat /proc/PID/attr/current(PID 是你的程序进程号),输出应含 myapp (enforce)myapp (complain);如果是 unconfined,说明 profile 没加载或匹配失败
  • 检查 profile 名称是否和二进制路径完全一致(包括符号链接):aa-status | grep myapp,若没出现,用 sudo aa-enforce /etc/apparmor.d/usr.bin.myapp 强制加载
  • systemd 服务要额外注意:ProtectSystem=NoNewPrivileges=PrivateTmp= 这些会覆盖 AppArmor 权限,得同步调整

AppArmor 的交互式工具依赖真实运行时行为,而不是静态分析。这意味着 profile 覆盖度完全取决于你“怎么用”那个程序——漏掉某个菜单、某个配置文件、某次网络请求,对应权限就会缺。别指望一次跑完就收工。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2678

2024.08.16

SSL检测工具介绍
SSL检测工具介绍

SSL检测工具有SSL Labs、SSL Check、SSL Server Test、SSLMate、SSL/TLS Analyzer等。详细介绍:1、SSL Labs是一个由Qualys提供的在线SSL检测工具,可以评估服务器证书的部署情况、加密套件、协议支持等方面的安全性,它提供了一个详细的报告,包括证书的颁发者、有效期、安全性配置等;2、SSL Check等等。

353

2023.10.20

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1521

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

715

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

791

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

584

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

563

2023.07.20

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

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

1030

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.6万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

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

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