首页 > 数据库 >MySQL5.7开启查询日志和审计日志

MySQL5.7开启查询日志和审计日志

时间:2024-01-17 20:56:12浏览次数:37  
标签:audit MySQL5.7 server syslog file mysql 日志 查询

Mysql审计日志

1、下载mariadb-5.5.56-linux-x86_64.tar.gz解压获取server_audit.so插件

下载链接:https://downloads.mariadb.org/mariadb-galera/5.5.56/#file_type=source

2、登录MySQL,执行命令获取MySQL的plugin目录

mysql> SHOW GLOBAL VARIABLES LIKE 'plugin_dir';
+---------------+--------------------------+
| Variable_name | Value |
+---------------+--------------------------+
| plugin_dir | /usr/lib64/mysql/plugin/ |
+---------------+--------------------------+
1 row in set (0.02 sec)

3、将server_audit.so上传到 /usr/lib64/mysql/plugin/下

4、在命令下安装server_audit.so

1 mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.so';

5、查看变量开启设置情况,默认貌似都是关闭的

mysql> show variables like '%audit%';
+-------------------------------+---------------------------------------------------+
| Variable_name | Value |
+-------------------------------+---------------------------------------------------+
| server_audit_events | CONNECT,QUERY,TABLE,QUERY_DDL,QUERY_DML,QUERY_DCL |
| server_audit_excl_users | |
| server_audit_file_path | /data/mysql/auditlogs/ |
| server_audit_file_rotate_now | ON |
| server_audit_file_rotate_size | 200000000 |
| server_audit_file_rotations | 200 |
| 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 |
+-------------------------------+---------------------------------------------------+

6、编辑my.cnf,添加配置

/etc/my.cnf

1 server_audit_events='CONNECT,QUERY,TABLE,QUERY_DDL,QUERY_DML,QUERY_DCL'
2 备注:指定哪些操作被记录到日志文件中
3 server_audit_logging=on
4 server_audit_file_path =/data/mysql/auditlogs/
5 备注:审计日志存放路径,该路径下会生成一个server_audit.log文件,就会记录相关操作记录了
6 server_audit_file_rotate_size=200000000
7 server_audit_file_rotations=200
8 server_audit_file_rotate_now=ON

注意:server_audit_file_path =/data/mysql/auditlogs/的目录需要开启权限 chmod 777 /data/mysql/auditlogs/ ,并且要关闭SElinux,否则无法生成日志。

7、重启服务,service mysqld restart

登录MySQL后发现,在MySQL环境下执行的任何命令都被记录到/data/mysql/auditlogs/server_audit.log,如果日志文件达到指定的大小,会自动切割

mysql> show variables like '%audit%';
+-------------------------------+---------------------------------------------------+
| Variable_name | Value |
+-------------------------------+---------------------------------------------------+
| server_audit_events | CONNECT,QUERY,TABLE,QUERY_DDL,QUERY_DML,QUERY_DCL |
| server_audit_excl_users | |
| server_audit_file_path | /data/mysql/auditlogs/ |
| server_audit_file_rotate_now | ON |
| server_audit_file_rotate_size | 200000000 |
| server_audit_file_rotations | 200 |
| 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 |
+-------------------------------+---------------------------------------------------+

8、参数说明:

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

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

9、卸载server_audit

1 mysql> UNINSTALL PLUGIN server_audit;
2 mysql> show variables like '%audit%';
3 Empty set (0.00 sec)

防止server_audit 插件被卸载,需要在配置文件中添加:

1 [mysqld]
2 server_audit=FORCE_PLUS_PERMANENT

重启MySQL生效

值得注意的是,应该在server_audit插件被安装好,并且已经运行之后添加这些配置,否则过早在配置文件添加这个选项,会导致MySQL发生启动错误!

1 mysql> UNINSTALL PLUGIN server_audit;
2 ERROR 1702 (HY000): Plugin 'server_audit' is force_plus_permanent and can not be unloaded

MySQL查询日志配置

在my.cnf 文件中配置

1 log-output=file
2 general-log=1
3 general-log-file=/path/to/query.log

标签:audit,MySQL5.7,server,syslog,file,mysql,日志,查询
From: https://www.cnblogs.com/pyng/p/17971148

相关文章

  • ES--自动补全查询
    elasticsearch提供了CompletionSuggester查询来实现自动补全功能。这个查询会匹配以用户输入内容开头的词条并返回。为了提高补全查询的效率,对于文档中字段的类型有一些约束:参与补全查询的字段必须是completion类型。字段的内容一般是用来补全的多个词条形成的数组。比......
  • C# 自定义日志中间件 ASP.NET Core Web API
    自定义日志中间件usingMicrosoft.AspNetCore.Builder;usingMicrosoft.AspNetCore.Http;usingMicrosoft.AspNetCore.Http.Extensions;usingMicrosoft.Extensions.DependencyInjection;usingMicrosoft.Extensions.Logging;usingNewtonsoft.Json;usingSystem;usingS......
  • 基于Venn-Abers预测器的系统日志异常检测方法_顾兆军
    title:基于Venn-Abers预测器的系统日志异常检测方法_顾兆军banner_img:https://cdn.studyinglover.com/pic/2023/12/334c0c129076533308cbc7e03f8c55be.pngdate:2024-1-1519:40:00tags:-机器学习基于Venn-Abers预测器的系统日志异常检测方法_顾兆军收集日志信息、日志......
  • 网络-华为、思科交换机配置TFTP自动备份、NTP时间同步、SYSLOG日志同步功能
    前言如今园区中交换机越来越多,传统的查看日志的方式是远程到交换机在命令行中查看,但是logbuffer中保存的容量有限,也不方便查询,耗费运维人员大量的经理,不好集中管理,syslog就为解决此问题,可以搭建一台syslog服务器(我使用群辉自带的功能),将日志集中收集起来。同样的交换机的配置也......
  • 千万级数据深分页查询SQL性能优化实践
    一、系统介绍和问题描述如何在Mysql中实现上亿数据的遍历查询?先来介绍一下系统主角:关注系统,主要是维护京东用户和业务对象之前的关注关系;并对外提供各种关系查询,比如查询用户的关注商品或店铺列表,查询用户是否关注了某个商品或店铺等。但是最近接到了一个新需求,要求提供查询关注对......
  • 千万级数据深分页查询SQL性能优化实践
    一、系统介绍和问题描述如何在Mysql中实现上亿数据的遍历查询?先来介绍一下系统主角:关注系统,主要是维护京东用户和业务对象之前的关注关系;并对外提供各种关系查询,比如查询用户的关注商品或店铺列表,查询用户是否关注了某个商品或店铺等。但是最近接到了一个新需求,要求提供查询关注......
  • IntelliJ IDEA快速查询maven依赖关系
    IntelliJIDEA快速查询maven依赖关系1.在Maven窗口中点击Dependencies->showDependencies2.得到依赖关系图此时原有快捷键Ctrl+f可以查询jar包,如果没有查询菜单出来则设置快捷键方式为File->Settings->Keymap->搜索栏输入find->在MainMenu下Edit下Find下Find双击算则Ad......
  • SpringBoot项目从0到1配置logback日志打印
    转载自:SpringBoot项目从0到1配置logback日志打印,作者sum墨一、写文背景我们在写后端项目的时候,日志打印是必需的。支持SpringBoot项目的日志框架一般有log4j、logback,这二者各有优劣,这里就不展开对比了。我们项目中常用的是logback框架,该框架主要是一个logback-spring.xml配置......
  • 查询字符串标签
    1.node表格ip|labels----------------+-------------------------------------------------------1.1.1.1|x_buildrv_build1.1.1.2|x_buildrv_build1.1.1.3|x_buildrv_build1.1.1.4......
  • FastAPI学习-30 项目代码中添加自己的日志内容
    前言前面一篇【FastAPI学习-29uvicorn使用log_config参数设置logger日志格式】已经学会了配置uvicorn的日志。如何在fastapi项目代码中添加自己的日志呢?添加日志创建一个logger实例,名称为"fast"fromfastapiimportFastAPIimportlogginglogger=logging.getLo......