当前位置:首页 > 技术 > 正文内容

CentOS系统MySQL数据库审计插件部署指南

访客 技术 2026年5月27日 3

一、获取审计插件文件

首先从MariaDB官方仓库下载包含审计插件的压缩包:

cd /usr/local/src
wget https://downloads.mariadb.com/MariaDB/mariadb-10.1.23/bintar-linux-x86_64/mariadb-10.1.23-linux-x86_64.tar.gz

二、解压并部署插件文件

将下载的压缩包解压,并提取审计插件到MySQL插件目录:

tar zxf mariadb-10.1.23-linux-x86_64.tar.gz
cd mariadb-10.1.23-linux-x86_64
cp lib/plugin/server_audit.so /usr/local/mysql/lib/plugin/
cd /usr/local/mysql/lib/plugin/
chown -R mysql:mysql server_audit.so
chmod 755 server_audit.so

三、加载审计插件

登录MySQL数据库,执行插件安装命令:

mysql -u root -p
mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.so';
Query OK, 0 rows affected (0.00 sec)

验证插件安装状态,查看相关配置参数:

mysql> SHOW VARIABLES LIKE '%audit%';
+-------------------------------+-----------------------+
| Variable_name                 | Value                 |
+-------------------------------+-----------------------+
| server_audit_events           |                       |
| server_audit_excl_users       |                       |
| server_audit_file_path        | server_audit.log      |
| server_audit_file_rotate_now  | OFF                   |
| server_audit_file_rotate_size | 1000000               |
| server_audit_file_rotations   | 9                     |
| server_audit_incl_users       |                       |
| server_audit_loc_info         |                       |
| server_audit_logging          | OFF                   |
| server_audit_mode             | 1                     |
| server_audit_output_type      | file                  |
| server_audit_query_log_limit  | 1024                  |
| server_audit_syslog_facility  | LOG_USER              |
| server_audit_syslog_ident     | mysql-server_auditing |
| server_audit_syslog_info      |                       |
| server_audit_syslog_priority  | LOG_INFO              |
+-------------------------------+-----------------------+
16 rows in set (0.00 sec)

四、临时启用审计功能

通过全局变量临时开启审计,配置日志文件路径及轮转参数:

mysql> SET GLOBAL server_audit_logging = ON;
Query OK, 0 rows affected (0.00 sec)

mysql> SET GLOBAL server_audit_file_path = '/var/lib/mysql/audit.log';
Query OK, 0 rows affected (0.00 sec)

mysql> SET GLOBAL server_audit_file_rotations = 10;
Query OK, 0 rows affected (0.00 sec)

mysql> SET GLOBAL server_audit_file_rotate_size = 1073741824;
Query OK, 0 rows affected (0.00 sec)

确认配置已生效:

mysql> SHOW VARIABLES LIKE '%audit%';
+-------------------------------+---------------------------------------+
| Variable_name                 | Value                                 |
+-------------------------------+---------------------------------------+
| server_audit_events           |                                       |
| server_audit_excl_users       |                                       |
| server_audit_file_path        | /var/lib/mysql/audit.log              |
| server_audit_file_rotate_now  | OFF                                   |
| server_audit_file_rotate_size | 1073741824                            |
| server_audit_file_rotations   | 10                                    |
| server_audit_incl_users       |                                       |
| server_audit_loc_info         |                                       |
| server_audit_logging          | ON                                    |
| server_audit_mode             | 1                                     |
| server_audit_output_type      | file                                  |
| server_audit_query_log_limit  | 1024                                  |
| server_audit_syslog_facility  | LOG_USER                              |
| server_audit_syslog_ident     | mysql-server_auditing                 |
| server_audit_syslog_info      |                                       |
| server_audit_syslog_priority  | LOG_INFO                              |
+-------------------------------+---------------------------------------+
16 rows in set (0.00 sec)

五、配置持久化生效

修改MySQL配置文件 /etc/my.cnf,在 [mysqld] 区块中添加以下参数:

[client]
port        = 3306
socket      = /tmp/mysql.sock

[mysqld]
# 审计插件配置
server_audit_logging = ON
server_audit_file_path = /var/lib/mysql/audit.log
server_audit = FORCE_PLUS_PERMANENT
server_audit_file_rotate_size = 1G
server_audit_file_rotations = 10

注意:server_audit = FORCE_PLUS_PERMANENT 参数可防止插件被意外卸载。

配置修改完成后,重启MySQL服务使配置生效:

systemctl restart mysqld
# 或使用
service mysqld restart

六、验证审计日志

审计日志默认按照配置路径生成,可通过以下命令查看:

cat /var/lib/mysql/audit.log
tail -f /var/lib/mysql/audit.log

日志记录示例:

20230113 17:11:48,centos7-1,root,localhost,1,3,QUERY,,'set global server_audit_logging=on',0
20230113 17:11:48,centos7-1,root,localhost,1,4,QUERY,,'set global server_audit_file_path=\'/var/lib/mysql/audit.log\'',0
20230113 17:15:00,centos7-1,root,localhost,1,0,CONNECT,,,0
20230113 17:15:00,centos7-1,root,localhost,1,1,QUERY,,'select @@version_comment limit 1',0
20230113 17:15:17,centos7-1,root,localhost,1,2,QUERY,,'create database test1',0
20230113 17:15:21,centos7-1,root,localhost,1,3,QUERY,,'create database test2',0
20230113 17:15:27,centos7-1,root,localhost,1,4,QUERY,,'drop database test1',0

日志字段含义:时间戳、主机名、用户、连接主机、连接ID、查询ID、操作类型、对象信息、SQL语句、执行结果。

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。