MySql教程

mysql开启审计功能

本文主要是介绍mysql开启审计功能,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

数据库版本:mysql5.7 (linux系统)

数据库日志审计功能插件:server_audit.so (下载mariadb-5.5.68-linux-x86_64.tar.gz,解压后获取mariadb-5.5.68-linux-x86_64/lib/plugin/server_audit.so)

部署方法:

1.登录MySQL,执行以下命令获取MySQL的plugin目录:

SHOW GLOBAL VARIABLES LIKE '%plugin_dir%';
1
如下图:

2.将 server_audit.so 插件上传到 /data/mysql/lib/plugin 下;

3.在mysql中执行以下命令,安装插件:

INSTALL PLUGIN server_audit SONAME 'server_audit.so';
1
如下图:

4.查看变量开启情况,默认都是关闭:

show variables like '%audit%';
1
如下图:

5.开启审计功能:

set global server_audit_logging=on;
1
如下图:

6.上述开启日志审计配置后,立即生效,重启mysql服务后,配置会失效,需要重新设置。如果想永久生效,可以在mysql配置文件 /etc/my.cnf 中 [mysqld] 下添加 server_audit_logging=on ,然后重启mysql服务即可。

7.查看审计日志:审计日志默认存储路径为:mysql/data/server_audit.log

8.关于审计插件其他参数配置说明如下:

详细请参考:https://mariadb.com/kb/en/mariadb/server_audit-system-variables/

参数    含义
server_audit_output_type    指定日志输出类型,可为SYSLOG或FILE
server_audit_logging    启动或关闭审计
server_audit_events    指定记录事件的类型,可以用逗号分隔的多个值(connect,query,table),如果开启了查询缓存(query cache),查询直接从查询缓存返回数据,将没有table记录
server_audit_file_path    如server_audit_output_type为FILE,使用该变量设置存储日志的文件,可以指定目录,默认存放在数据目录的server_audit.log文件中
server_audit_file_rotate_size    限制日志文件的大小
server_audit_file_rotations    指定日志文件的数量,如果为0日志将从不轮转
server_audit_file_rotate_now    强制日志文件轮转
server_audit_incl_users    指定哪些用户的活动将记录,connect将不受此变量影响,该变量比server_audit_excl_users优先级高
server_audit_syslog_facility    默认为LOG_USER,指定facility
server_audit_syslog_ident    设置ident,作为每个syslog记录的一部分
server_audit_syslog_info    指定的info字符串将添加到syslog记录
server_audit_syslog_priority    定义记录日志的syslogd priority
server_audit_excl_users    该列表的用户行为将不记录,connect将不受该设置影响

 

这篇关于mysql开启审计功能的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!