首页 > 数据库 >mysql开启审计(windows)

mysql开启审计(windows)

时间:2023-05-30 11:23:34浏览次数:42  
标签:audit set windows 开启 server file mysql localhost

环境:

OS:windows 2008

DB:mysql 5.7

 

1.获取到安全审计插件
可以下载mariadb后,解压找到server_audit.ddl
我这里下载的mariadb版本是10.4.29
下载地址:https://mariadb.org/download/


2.将server_audit.ddl 拷贝到mysql插件的路径下
路径为:D:\mysql57\lib\plugin

 

3.登录mysql安装插件
C:\Users\Administrator.WIN-ADSERVER>mysql -h localhost -uroot -pmysql -P13306

mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.dll';
Query OK, 0 rows affected (0.06 sec)

4.检查审计功能是否开启,没有开启则开启

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.03 sec)


6.开启审计功能
先创建审计存储目录
[root@localhost mysql57]#mkdir -p /opt/mysql57/audit
[root@localhost mysql57]#chown -R mysql:mysql ./audit/

在D:\mysql57目录下创建审计目录audit
完整的审计目录为
D:\mysql57\audit

 

开启审计
mysql>set global server_audit_logging=on;
mysql>set global server_audit_file_path='D:\mysql57\audit';
mysql>set global server_audit_file_rotate_size=200000000;
mysql>set global server_audit_file_rotations=200;
mysql>set global server_audit_file_rotate_now=ON;

好像不需要重启就会产生审计日志了,避免重启参数失效需要将如下配置项加入到启动参数.

 

7.将如下配置添加到初始化文件
server_audit_logging=on
server_audit_file_path =D:\\mysql57\\audit
server_audit_file_rotate_size=200000000
server_audit_file_rotations=200
server_audit_file_rotate_now=ON

 

8.验证
mysql> create database db_hxl;
Query OK, 1 row affected (0.04 sec)

查看审计日志 server_audit.log
会有相应的记录
20200414 09:02:53,localhost.localdomain,root,localhost,6,10,QUERY,,'set global server_audit_file_rotate_now=ON',0
20200414 09:03:09,localhost.localdomain,root,localhost,6,11,QUERY,,'show variables like \'%audit%\'',0
20200414 09:05:25,localhost.localdomain,root,localhost,6,12,QUERY,,'show databases',0
20200414 09:05:33,localhost.localdomain,root,localhost,6,13,QUERY,,'create database db_hxl',0
20200414 09:06:36,localhost.localdomain,root,localhost,6,14,QUERY,,'SELECT DATABASE()',0

 

9.参数说明:
详细请参考: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将不受该设置影响
server_audit_mode:标识版本,用于开发测试

 

10.卸载server_audit
mysql> UNINSTALL PLUGIN server_audit;
mysql> show variables like '%audit%';
Empty set (0.00 sec)
防止server_audit 插件被卸载,需要在配置文件中添加:
[mysqld]
server_audit=FORCE_PLUS_PERMANENT
重启MySQL生效

值得注意的是,应该在server_audit插件被安装好,并且已经运行之后添加这些配置,否则过早在配置文件添加这个选项,会导致MySQL发生启动错误!
mysql> UNINSTALL PLUGIN server_audit;
ERROR 1702 (HY000): Plugin 'server_audit' is force_plus_permanent and can not be unloaded


11.关闭审计

set global server_audit_logging=off;

 

12.不审计查询

set global server_audit_events='connect,table,query_ddl,query_dcl,query_dml_no_select';

 

 

标签:audit,set,windows,开启,server,file,mysql,localhost
From: https://www.cnblogs.com/hxlasky/p/17442722.html

相关文章

  • es mysql 适用场景对比
    esmysql适用场景对比问题一全文检索毫无疑问直接上es,那么除了这种场景,什么时候该选es?为啥mysql不行?对枚举字段的搜索mysql创建索引的原则是对于那些区别度高字段建立索引,区别度越高的索引,在数据量大的情况下,索引效果越好。因为mysql建立b+树时是这样,每创建一行就新建立索引......
  • 【EXPLAIN】MySQL执行计划分析
    目录什么是执行计划?如何获取执行计划?执行计划结果分析idselect_typetabletype(重要)possible_keyskey(重要)key_lenrowsExtra(重要)什么是执行计划?执行计划是指一条SQL语句在经过MySQL查询优化器的优化会后,具体的执行方式。执行计划通常用于SQL性能分析、优化等场景。通过EXP......
  • 手摸手带你 在Windows系统中安装Istio
    Istio简介通过负载均衡、服务间的身份验证、监控等方法,Istio可以轻松地创建一个已经部署了服务的网络,而服务的代码只需很少更改甚至无需更改。通过在整个环境中部署一个特殊的sidecar代理为服务添加Istio的支持,而代理会拦截微服务之间的所有网络通信,然后使用其控制平面的功......
  • MySQL-日期时间类型比较、互转
    【原理】日期、时间类型比较比较的是时间戳,即long型 【原理】日期、时间类型和字符串比较当涉及日期类型、时间类型和字符串类型比较时,会先将字符串转换成日期、时间类型,然后进行比较;例如:date_col<"2020-09-01",date_col是date类型,在比较时,会先将"2020-09-01"转换成dat......
  • windows系统如何禁用组策略(修改注册表)
    1、在电脑桌面使用快捷键win键+R唤出运行窗口,输入regedit,点击确定。2、在注册表编辑器左侧窗口中依次点击展开\HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Policies,选中其下的Explorer。3、在右侧空白处点击右键,依次点击新建—DWORD(32位)值。4、命名为R......
  • 误删生产数据?利用mysql的Binlog进行恢复操作
    恢复至某个时间段的Mysql操作,和查看sql重新执行被删sql如果不小心删除了生产数据,你又想批量恢复,只要你的mysql开启了binlog,那么是可以恢复的。1、检查是否开启binlogshowvariableslike'log_%';保证为ON,记录下log_bin_basename,这是你的binlog存放位置如:/var/lib/mysql......
  • Windows 局域网批量安装可以帮助您快速在局域网内的多台计算机上部署 Windows 操作系
    Windows局域网批量安装可以帮助您快速在局域网内的多台计算机上部署Windows操作系统,提高部署效率。以下是基于WindowsServer环境下常用的局域网批量安装方法:基于Windows部署服务(WDS)的批量安装Windows部署服务(WDS)是用于集中式部署Windows操作系统的一种Windows......
  • net6 使用 efcore 根据 mysql数据库生成代码
    1.vs中下载程序NuGet包Microsoft.EntityFrameworkCore.ToolsPomelo.EntityFrameworkCore.MySql 把这两个安装好就可以了或者你嫌麻烦也可以直接用命令下载 打开VS2019"工具"->"Nuget包管理器"->"程序包器管理控制台"PM>Install-PackageMicrosoft.EntityFrameworkCore.Too......
  • 通过 docker-compose 快速部署 MySQL保姆级教程
    目录一、概述二、前期准备1)部署docker2)部署docker-compose三、创建网络四、MySQL编排部署1)构建镜像Dockerfile2)配置文件2)编排docker-compose.yaml3)开始部署五、简单测试验证六、常用的MySQL客户端命令1)连接到MySQL服务器2)显示当前数据库列表3)选择数据库4)显示当前数据库的所......
  • Windows 11 截屏快捷键被占用
    Windows11系统截屏快捷键被占用后如何进行撤销。在更新系统后,发现Windows11的系统快捷键被占用了,导致其他软件无法使用这个快捷键。我们需要做的是取消选择上面那个选项。  在完成上面的设置后,重启计算机就可以让你的计算机把占用的截屏快捷键释放了。https://www.o......