0

0

Linux服务器如何集中审计_操作留痕实现技巧【技巧】

冷炫風刃

冷炫風刃

发布时间:2025-12-23 22:24:32

|

360人浏览过

|

来源于php中文网

原创

Linux服务器集中审计和操作留痕可通过auditd、bash history联动rsyslog、Loki+Grafana实现,涵盖命令记录、权限追踪、日志集中分析与告警,且需权限分离与规则自检。

linux服务器如何集中审计_操作留痕实现技巧【技巧】

Linux服务器集中审计和操作留痕,核心在于统一日志采集、命令行为记录、权限操作追踪与时间线还原。不依赖第三方商业平台,也能用开源组件扎实落地。

启用并加固系统级审计:auditd 是基石

auditd 是 Linux 内置的内核级审计框架,能捕获系统调用、文件访问、用户登录、权限变更等底层事件。

  • 安装并启动服务:sudo apt install auditd(Debian/Ubuntu)或 sudo yum install audit(CentOS/RHEL),然后 sudo systemctl enable --now auditd
  • 关键规则示例(写入 /etc/audit/rules.d/custom.rules):
    -a always,exit -F arch=b64 -S execve -k command_exec(记录所有命令执行)
    -w /etc/passwd -p wa -k identity_change(监控账号文件修改)
    -w /var/log/audit/ -p wa -k audit_log(保护审计日志自身)
  • 重载规则:sudo augenrules --load,验证是否生效:sudo ausearch -m EXECVE -ts recent | head -5

记录用户交互式命令:bash history + syslog 联动

仅靠 auditd 不足以还原完整操作上下文(如命令参数、执行目录、终端会话)。需结合 shell 日志增强可读性。

  • /etc/bash.bashrc 或全局 profile 中添加:
    export HISTTIMEFORMAT="%Y-%m-%d %T "
    export PROMPT_COMMAND='RETRN_VAL=$?;logger -p local6.info "$(whoami) [$$] $(history 1 | sed "s/^[ ]*[0-9]\+[ ]*//") [$RETRN_VAL]"'
  • 配置 rsyslog 将 local6 日志转发至中央日志服务器(如使用 /etc/rsyslog.d/50-remote.conf):
    local6.* @central-logger.example.com:514(UDP)或 @@central-logger.example.com:514(TCP)
  • 确保用户 shell 是 bash(非 sh/nologin),且未禁用 history(检查 HISTSIZEHISTFILE

集中收集与结构化分析:ELK 或 Loki + Grafana

分散的日志无法支撑快速检索与行为画像。推荐轻量高效的组合:

知了追踪
知了追踪

AI智能信息助手,智能追踪你的兴趣资讯

下载
  • Loki(无索引、基于标签的日志聚合)+ Promtail(日志采集器)+ Grafana(查询与看板)
    配置 Promtail 抓取 /var/log/audit/audit.log/var/log/syslog,打上 hostroleenv 等标签
  • 在 Grafana 中建 dashboard,常用查询示例:
    {job="system-audit"} |~ "execve|chmod|chown" | line_format "{{.log}}"
    {host="web01"} | json | __error__ =="" | status >= 400(若集成应用日志)
  • 设置告警规则:例如 5 分钟内同一用户执行 >10 次 sudo su -,或出现 rm -rf / 类高危命令关键词

权限与审计分离:避免审计员被绕过

审计能力必须独立于被审计对象,否则形同虚设。

  • 审计日志路径(如 /var/log/audit/)设为 root:root,权限 700,禁止普通用户读写
  • 禁用 root 直接登录,所有提权走 sudo 并强制记录(Defaults logfile=/var/log/sudo.log + Defaults log_input,log_output
  • 定期校验审计规则完整性:sudo auditctl -s | grep enabled 应为 1;用 aureport --summary 检查事件量突降(可能被停用或磁盘满)
  • 关键操作(如新增 sudoer、修改 audit 规则)本身也要进审计流——用 -w /etc/sudoers* -p wa -k sudoers_change 等规则兜底

不复杂但容易忽略。真正有效的审计不是堆日志,而是让每条记录可归属、可关联、可回溯、可告警。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

389

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

571

2023.08.10

tcp和udp的区别
tcp和udp的区别

TCP和UDP的区别,在连接性、可靠性、速度和效率、数据报大小以及适用场景等方面。本专题为大家提供tcp和udp的区别的相关的文章、下载、课程内容,供大家免费下载体验。

119

2023.07.25

udp是什么协议
udp是什么协议

UDP是OSI参考模型中一种无连接的传输层协议。本专题为大家带来udp是什么协议的相关文章,免费提供给大家。

281

2023.08.08

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

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

20

2026.01.15

热门下载

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

精品课程

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

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

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

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