mysql如何开启审计

环境:

OS:Centos

DB:mysql 5.7

1.获取到安全审计插件
可以下载mariadb后,解压找到server_audit.so
我这里下载的mariadb版本是10.4

2.将server_audit.so 拷贝到mysql插件的路径下
[root@localhost plugin]#cp /soft/server_audit.so /opt/mysql57/lib/plugin/

3.拷贝过去后注意修改下权限
[root@localhost plugin]# chown mysql:mysql ./server_audit.so


4.登录mysql安装插件
mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.so';
Query OK, 0 rows affected (0.06 sec)

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

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/
开启审计
mysql>set global server_audit_logging=on;
mysql>set global server_audit_file_path='/opt/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 =/opt/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)

查看审计日志
[root@localhost audit]# more 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

-- The End --

猜你喜欢

转载自www.cnblogs.com/hxlasky/p/12695752.html