mysql 审计插件_MySQL审计插件使用

本教程详细介绍了如何下载、安装和配置MySQL审计插件。首先从mcafee官网下载审计插件,然后将libaudit_plugin.so复制到plugin_dir目录并设置权限。接着通过INSTALL PLUGIN命令安装插件,并启用审计功能。最后,调整审计记录参数和日志配置,实现审计日志的管理和分割。
摘要由CSDN通过智能技术生成

下载MySQL审计插件

https://github.com/mcafee/mysql-audit/releases

or

本文使用mcafee官网下载链接的软件:

https://dl.bintray.com/mcafee/mysql-audit-plugin/

详细的配置可以参考官方文档:

https://github.com/mcafee/mysql-audit/wiki/Installation

解压文件:

unzip audit-plugin-mysql-5.7-1.1.7-805-linux-x86_64.zip

将安装包libaudit_plugin.so文件复制到 plugin_dir目录:

root@localhost 10:07:  [(none)]>show global variables like 'plugin_dir';

+---------------+------------------------------+

| Variable_name | Value                        |

+---------------+------------------------------+

| plugin_dir    | /usr/local/mysql/lib/plugin/ |

+---------------+------------------------------+

1 row in set (0.00 sec)

cp audit-plugin-mysql-5.7-1.1.7-805/lib/libaudit_plugin.so /usr/local/mysql/lib/plugin/

chmod +x /usr/local/mysql/lib/plugin/libaudit_plugin.so

安装插件:

root@localhost 10:18:  [(none)]>INSTALL PLUGIN AUDIT SONAME 'libaudit_plugin.so';

Query OK, 0 rows affected (0.73 sec)

确认:

root@localhost 10:18:  [(none)]>root@localhost 10:18:  [(none)]>SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE 'audit%';

+-------------+---------------+

| PLUGIN_NAME | PLUGIN_STATUS |

+-------------+---------------+

| AUDIT       | ACTIVE        |

+-------------+---------------+

1 row in set (0.00 sec)

审计默认不开启,开启审计:

set global audit_json_file=on;

set global audit_record_cmds='delete,update,create_table,create_db,drop_db,drop_table,alter_table,grant,truncate';

查看audit日志输出名称:

root@localhost 10:23:  [(none)]>show global variables like 'audit_json_log_file';

+---------------------+------------------+

| Variable_name       | Value            |

+---------------------+------------------+

| audit_json_log_file | mysql-audit.json |

+---------------------+------------------+

1 row in set (0.00 sec)

编辑配置文件添加:

[mysqld]

audit_json_file=on

audit_record_cmds='delete,update,create_table,create_db,drop_db,drop_table,alter_table,grant,truncate'

mysql-audit.json文件默认在datadir下面,查看审计日志内容:

tail -f mysql-audit.json

{"msg-type":"activity","date":"1552273694556","thread-id":"3","query-id":"13","user":"root","priv_user":"root","ip":"","host":"localhost","connect_attrs":{"_os":"linux-glibc2.12","_client_name":"libmysql","_pid":"20105","_client_version":"5.7.24","_platform":"x86_64","program_name":"mysql"},"pid":"20105","os_user":"root","appname":"mysql","status":"0","cmd":"create_db","query":"create database app_store"}

常用参数说明:

1. audit_json_file=on|off

是否开启audit功能

2. audit_json_log_file

审计文件的路径和名称信息

3. audit_record_cmds

audit记录的命令,默认为记录所有命令

可以根据需要设置为任意dml、dcl、ddl的组合:

例如:audit_record_cmds="select,insert,delete,update"

4. audit_record_objs

audit记录操作的对象或表,默认为记录所有对象

也可以指定为下面的格式

audit_record_objs="*.table_name,db_name.*,db_name.table_name"

5. audit_whitelist_users

可以设置白名单:

如set global audit_whitelist_users="root,admin";

如果你的audit审计的日志较多,可以考虑日志分割,设置日志压缩和保留天数:

vi /etc/logrotate.d/mysql-audit

/data/mysql/data/mysql-audit.json {

daily

copytruncate

compress

rotate 7

dateext

dateformat .%Y-%m-%d

}

手动生成日志切割:

logrotate -vf /etc/logrotate.d/mysql-audit

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值