Mysql8启用日志审计插件

概述

等保要求,数据库启用日志审计。Mysql8上面使用开源插件audit-plugin-for-mysql(MariaDB的审计插件不用折腾了,无论直接使用还是编译使用,在Mysql8上都不行)

插件下载

  • 日志审计插件下载地址:
    https://codeload.github.com/Vettabase/audit-plugin-for-mysql/zip/refs/heads/mysql-8.0

插件安装

    1. 解压下载文件
unzip audit-plugin-for-mysql-mysql-8.0.zip
    1. 找到mysql插件存储目录
mysql> SHOW VARIABLES LIKE 'plugin_dir';
+---------------+--------------------------+
| Variable_name | Value                    |
+---------------+--------------------------+
| plugin_dir    | /usr/lib64/mysql/plugin/ |
+---------------+--------------------------+
1 row in set (0.01 sec)mysql> 
    1. 拷贝插件并赋权
cp audit-plugin-for-mysql-mysql-8.0/build/server_audit.so /usr/lib64/mysql/plugin/
chown  mysql:mysql  /usr/lib64/mysql/plugin/server_audit.so
chmod  755  /usr/lib64/mysql/plugin/server_audit.so
    1. 编辑Mysql配置文件
vim /etc/my.cnf# 配置server_audit 参数,根据实际情况调整
plugin_load_add = server_audit
#plugin_load_add = server_audit.so  # 确保插件开机加载
server_audit = FORCE_PLUS_PERMANENT  # 防止插件被卸载:cite[5]:cite[9]
server_audit_logging = ON
server_audit_events = 'CONNECT,QUERY_DDL,QUERY_DCL'
server_audit_file_path = /var/log/mysql/audit.log
server_audit_file_rotate_size = 0  # 禁用
server_audit_file_rotations = 0    # 禁用
#server_audit_excl_users = root  # 排除root用户
    1. 安装插件
mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.so';
Query OK, 0 rows affected (0.09 sec)mysql> 
    1. 检查审计日志
[root@centos7-05145 mysql]# ll /var/log/mysql
总用量 72
-rw-r----- 1 mysql mysql  4760 624 10:00 audit.log
-rw-r----- 1 mysql mysql 19094 624 09:12 mysql_3306-error.log
-rw-r----- 1 mysql mysql 43378 624 09:53 mysql_3306-slow.log

配置日志保存

  • 创建 logrotate配置文件
 vim /etc/logrotate.d/mysql_audit 
  • 添加以下内存并保存(本机配置185天是示例,保存6个月日志请考虑合理备份方案)
  • 如果要求日志保存严谨,请不要使用copytruncate方式,请参考以下postrotate示例
/var/log/mysql/audit.log {# 每天轮转一次daily# 保留185天的日志rotate 185# 压缩旧日志compress# 延迟1天压缩delaycompress# 如果日志不存在也不报错missingok# 空日志不轮转notifempty# 复制后截断原文件(避免重启)copytruncate# 使用mysql账号操作su mysql mysql# 设置文件日期后缀dateextdateformat -%Y%m%d
}
#/var/log/mysqld.log {
#        create 640 mysql mysql
#        notifempty
#        daily
#        rotate 5
#        missingok
#        compress
#    postrotate
#       # just if mysqld is really running
#       if test -x /usr/bin/mysqladmin && \
#          /usr/bin/mysqladmin ping &>/dev/null
#       then
#          /usr/bin/mysqladmin flush-logs
#       fi
#    endscript
#}
  • 检查cron状态(确保开机运行)
systemctl status crond● crond.service - Command SchedulerLoaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)Active: active (running) since 五 2025-05-23 10:52:13 CST; 1 months 1 days agoMain PID: 1331 (crond)CGroup: /system.slice/crond.service└─1331 /usr/sbin/crond -n523 10:52:13 centos7-172-028-002-001 systemd[1]: Started Command Scheduler.
523 10:52:13 centos7-172-028-002-001 crond[1331]: (CRON) INFO (Syslog will be used instead of sendmail.)
523 10:52:13 centos7-172-028-002-001 crond[1331]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 79% if used.)
523 10:52:13 centos7-172-028-002-001 crond[1331]: (CRON) INFO (running with inotify support)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/88511.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/88511.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习-线性模型

目录 线性模型 1、线性回归: 2、对数几率回归: 3、线性判别分析: 4、多分类学习: 5、类别不平衡问题: 基本数理知识补充: 损失函数: 凹凸函数 梯度下降 线性模型 线性模型形式简单、易…

Git上传代码如何解决Merge冲突

示例 解决方案 1、第一步切到本地的主分支 git checkout master2、拉取线上最新的代码 git pull3、切到本地自己的分支 gco feat-xx4、将代码从master变基&#xff08;移动/合并&#xff09;过来 git rebase master5、手动解决冲突 <<<<<<< HEAD 本…

fluentd + elasticsearch + grafana 不能显示问题

fluentd中配置log 源文件后&#xff0c;再配置elasticsearch后&#xff0c; elasticsearch pod中查询日志记录正常。 修改log 文件 后&#xff0c; elasticsearch pod中查询日志记录更新也正常。 但是在grafana中添加elasticsearch data source后&#xff0c; 连接正常&#…

《分布式事务新形态:AT模式如何被Seata TCC击穿》的深度解析,包含AT死锁原理/TCC原子性保障/Service Mesh深度集成三大硬核模块

一、AT模式的死刑判决&#xff1a;全局锁引发的血案 1.1 死锁现场还原&#xff08;支付宝真实案例&#xff09; 1.2 全局锁原理与缺陷 二、TCC模式的绝地反击&#xff1a;原子性保障三板斧 2.1 TCC核心架构设计 2.2 幂等控制原子防护网 三、Service Mesh深度集成&#xf…

【Elasticsearch】es初识,在项目架构中的用途,与mysql和kafka的配合使用,

ES是一个开源的高扩展的分布式全文检索引擎 在项目已有mysql增删改查的情况下&#xff0c;新增kafka&#xff0c;es流程 用户新增/修改商家&#xff08;写MySQL&#xff09; ↓ Kafka 生产者发送商家数据消息 ↓ Kafka 消费者监听消息 → 写入 Elasticsearch ↓ 前端搜索商家时…

【DataWhale组队学习】AI办公实践与应用-数据分析

AI办公&#xff1a;数据分析 1. 使用大模型进行数据分析的常见流程 把数据扔给AI让AI自动分析&#xff0c;并告诉你结果 下面我们对上面两个步骤进行详细说明 2. 使用大模型进行数据分析 2.1 将数据扔给大模型 2.1.1 选择合适的办公大模型 要使用大模型进行数据分析时&a…

5G 浪潮:发展全景、困境突围与未来航向

在当今数字化浪潮中&#xff0c;5G 技术宛如一颗璀璨的明星&#xff0c;照亮了各个行业前行的道路。自 5G 正式商用以来&#xff0c;它不仅深刻改变了人们的生活方式&#xff0c;更在工业、农业、交通等领域掀起了一场数字化转型的革命。本文将深入探讨 5G 技术的原理、发展现状…

理论加案例,一文读懂数据分析中的分类建模

一、什么是分类 分类&#xff0c;是数据建模领域的重要分支&#xff0c;你每天也都会接触。 手机垃圾短信过滤&#xff0c;就是分类算法给短信打的标签&#xff0c;比如0代表正常短信&#xff0c;1代表垃圾短信。 在医学领域&#xff0c;根据影像检查判断肿瘤是良性还是恶性。…

数组题解——二分查找【LeetCode】

704. 二分查找 算法逻辑分析 初始化边界 left 设为0&#xff0c;right 设为len(nums)&#xff0c;表示左闭右开区间 [left, right)。这意味着搜索区间包含下标left&#xff0c;但不包含下标right。 循环条件 while left < right:&#xff0c;只要left小于right&#xff0c…

Function AI 工作流发布:以 AI 重塑企业流程自动化

作者&#xff1a;寒斜 在 AI 技术飞速发展的今天&#xff0c;企业的流程自动化方式也正在发生深刻变革。过去&#xff0c;流程自动化往往依赖于人工配置和固定规则&#xff0c;难以适应复杂、多变的业务场景。而如今&#xff0c;随着 LLM&#xff0c;Agent&#xff0c;MCP 等节…

【单元测试】单元测试的定义和作用

介绍 ‌单元测试不仅是对函数进行测试&#xff0c;还包括对类、组件等最小可测试单元的测试‌。单元测试是对软件中的最小可测试单元进行验证的过程&#xff0c;这些单元可以是函数、方法、类或组件等。单元测试的主要目的是确保这些最小单元在隔离的环境中能够正确地实现其功…

AI 辅助生成 Mermaid 流程图

文章目录 背景Mermaid使用 AI 编写 Mermaid应用 背景 在 markdown 文档中虽然可以插入图片&#xff0c;但是也需要管理图片&#xff0c;一旦图片位置变了&#xff0c;文档中的图片就无法显示。图片占用空间较大&#xff0c;对于在线文档&#xff0c;为了加载速度&#xff0c;能…

定位坐标系深度研究报告

一、引言 定位坐标系是用于描述地理位置的数学工具&#xff0c;其发展与人类对地球形状的认知和技术需求密切相关。早期的定位依赖于天文观测&#xff08;如经纬度&#xff09;&#xff0c;现代则结合卫星技术&#xff08;如GPS&#xff09;和数学投影方法&#xff08;如墨卡托…

数字孪生技术引领UI前端设计潮流:沉浸式体验的新篇章

hello宝子们...我们是艾斯视觉擅长ui设计、前端开发、数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 当虚拟世界与物理现实的边界逐渐模糊&#xff0c;数字孪生技术正以燎原之势重构 UI 前端设计的…

VR油库虚拟仿真系统:开启智慧油库新时代

在科技快速发展的当下&#xff0c;VR 技术在多行业广泛应用&#xff0c;以沉浸式等特点重塑行业模式。油库作为石油储存与转运关键枢纽&#xff0c;传统运营管理依赖人工经验和常规设备&#xff0c;存在安全风险高、培训成本大等问题。在此背景下&#xff0c;油库引入 VR 虚拟仿…

Oracle获取前100条记录

在Oracle数据库中&#xff0c;获取前100条记录可以通过多种方式实现&#xff0c;最常见的方法是使用ROWNUM或者在较新版本的Oracle中使用FETCH FIRST子句。以下是几种常见的方法&#xff1a; 方法1&#xff1a;使用ROWNUM ROWNUM是Oracle特有的一个伪列&#xff0c;用于为结果…

【开源库 | libpng】使用 libpng 读写 png 文件详细教程(附带源码)

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

Nuttx之nxsched_add_readytorun(non-SMP)

声明&#xff1a;此处代码分析&#xff0c;来源与 nuttx 12.8.0版本。 在分析之前&#xff0c;需要一图镇楼。 /***************************************************************************** Name: nxsched_add_readytorun** Description:* This function adds a TCB …

Nuttx之nxsched_add_blocked

声明&#xff1a;此处代码分析&#xff0c;来源与 nuttx 12.8.0版本。 在分析之前&#xff0c;需要一图镇楼。 /***************************************************************************** Name: nxsched_add_blocked** Description:* This function adds a TCB to o…

python 包含虚拟环境venv项目的移动

python 包含虚拟环境venv项目的移动 在ubuntu环境下&#xff0c;移动一个包含venv虚拟环境的项目后&#xff0c;在执行时会报错: 错误1&#xff1a; Traceback (most recent call last):File "app.py", line 2, in <module>from flask import Flask, request…