0

0

大量 AVC denied 日志的 ausearch -m avc -ts recent 快速过滤脚本

冷炫風刃

冷炫風刃

发布时间:2026-01-19 10:57:42

|

920人浏览过

|

来源于php中文网

原创

该脚本通过ausearch与awk实现AVC拒绝事件的去重聚合与关键字段精简,仅保留scontext、tcontext、tclass、perm及path/name,剔除冗余信息,提升SELinux故障排查效率。

大量 avc denied 日志的 ausearch -m avc -ts recent 快速过滤脚本

直接用 ausearch -m avc -ts recent 查 AVC 日志虽然快,但默认输出包含大量重复、无关或低价值条目(比如同一路径被多次拒绝的 audit 记录),人工筛查效率低。下面是一个轻量、即用的过滤脚本,聚焦真正需要关注的策略冲突点。

核心过滤逻辑:去重 + 聚合 + 关键字段精简

不依赖外部工具(如 awk 复杂脚本或 python),纯 shell 实现,适配大多数 RHEL/CentOS/Fedora 系统:

#!/bin/bash
# avc-filter.sh — 快速提取高信息量 AVC 拒绝事件
ausearch -m avc -ts recent 2>/dev/null | \
awk -F': ' '
/avc:.*denied/ {
    # 提取关键字段:类型、操作、目标、路径(若存在)
    for(i=1; i<=NF; i++) {
        if($i ~ /scontext=/) sctx = $i
        else if($i ~ /tcontext=/) tctx = $i
        else if($i ~ /tclass=/) tcls = $i
        else if($i ~ /perm=/ || $i ~ /perms=/) perm = $i
        else if($i ~ /name="/) name = $i
        else if($i ~ /path=/) path = $i
    }
    # 合并为唯一签名(忽略时间戳和 pid 等易变字段)
    sig = sctx " " tctx " " tcls " " perm " " ((path!="")?path:name)
    if(!seen[sig]++) print sig
}'

使用方式(复制即用)

  • 终端中直接运行:bash -c 'ausearch -m avc -ts recent 2>/dev/null | awk -F\": \" \"/avc:.*denied/{...}"'(把上面 awk 部分粘贴进去)
  • 保存为 avc-filter.sh,加执行权限:chmod +x avc-filter.sh,然后运行 ./avc-filter.sh
  • 想看最近 5 分钟:把 -ts recent 换成 -ts $(date -d "5 minutes ago" "+%m/%d/%H:%M:%S")

为什么这样过滤更有效

  • 按策略签名去重:相同 scontext/tcontext/tclass/perms/path 组合只报一次,避免同一问题刷屏
  • 保留上下文关键项:SELinux 上下文(scontext/tcontext)、访问类型(tclass)、被拒动作(perm)、目标路径(path)全在一行,方便快速定位是哪个服务、哪个文件、什么权限出问题
  • 跳过无意义字段:不显示 avc 消息头、pid、comm、exe 等次要信息,减少视觉干扰
  • 兼容性好:仅依赖 ausearch 和 awk,无需安装 semanage、sesearch 或其他 SELinux 工具

后续建议:配合 sealert 快速诊断

拿到过滤后的关键 AVC 行,可直接喂给 sealert 获取修复建议:

千问APP
千问APP

阿里最强大模型官方AI助手

下载
# 示例:对某条过滤结果生成分析
echo "scontext=system_u:system_r:httpd_t:s0 tcontext=system_u:object_r:admin_home_t:s0 tclass=dir perms=search" | sealert -a /dev/stdin

它会告诉你是否已有对应 boolean、是否要改标签、是否需自定义策略模块,比纯看日志高效得多。

相关专题

更多
PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

41

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

101

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

148

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

57

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

19

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

108

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

45

2026.01.15

热门下载

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

精品课程

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

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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