mysql审计

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: mysql,审计,audit

环境:mysql5.7.19+centos 7

一,审计安装:

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

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/下安装

#mkdir -p /data/home/admin/mysql/auditlogs/
mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.so';
mysql> show variables like '%audit%';

4、编辑my.cnf,添加配置,指定哪些操作被记录到日志文件中

server_audit_logging=on
server_audit_file_path =/data/home/admin/mysql/auditlogs/  
server_audit_file_rotate_size=200000000
server_audit_file_rotations=200
server_audit_file_rotate_now=ON

5、重启服务,查看审计相关状态

#service mysqld restart
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 |
+-------------------------------+---------------------------------------------------+

6、参数说明:

详细请参考: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:标识版本,用于开发测试

7、卸载server_audit

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

8、审计日志:

image

二,开启审计后对mysql进行压力测试:

#unzip sysbench-master.zip
#yum install automake  autoconf libtool  libsysfs-dev  -y
#cd sysbench-master
#./autogen.sh
#./configure --prefix=/usr/local/sysbench
#make && make install

准备测试数据:

#sysbench /usr/local/sysbench/share/sysbench/oltp_read_write.lua --mysql-host=10.200.172.56 --mysql-port=3306 --mysql-user=root --mysql-password='root' --mysql-db=sbtest --db-driver=mysql --tables=10 --table-size=300000 --report-interval=10 --threads=128 prepare

开始测试:

sysbench /usr/local/sysbench/share/sysbench/oltp_read_write.lua --mysql-host=10.200.172.56 --mysql-port=3306 --mysql-user=root --mysql-password='root' --mysql-db=sbtest --db-driver=mysql --tables=10 --table-size=300000 --report-interval=10 --threads=128  run

测试完成清除数据:

sysbench /usr/local/sysbench/share/sysbench/oltp_read_write.lua --mysql-host=10.200.172.56 --mysql-port=3306 --mysql-user=root --mysql-password='root' --mysql-db=sbtest --db-driver=mysql --tables=10 --table-size=300000 --report-interval=10 --threads=128  run

测试结果分析:

-- 每10秒钟报告一次测试结果,tps、每秒读、每秒写、99%以上的响应时长统计

[  10s] threads: 8, tps: 1111.51, reads/s: 15568.42, writes/s: 4446.13, response time: 9.95ms (99%)
[  20s] threads: 8, tps: 1121.90, reads/s: 15709.62, writes/s: 4487.80, response time: 9.78ms (99%)
[  30s] threads: 8, tps: 1120.00, reads/s: 15679.10, writes/s: 4480.20, response time: 9.84ms (99%)
[  40s] threads: 8, tps: 1114.20, reads/s: 15599.39, writes/s: 4456.30, response time: 9.90ms (99%)
[  50s] threads: 8, tps: 1114.00, reads/s: 15593.60, writes/s: 4456.70, response time: 9.84ms (99%)
[  60s] threads: 8, tps: 1119.30, reads/s: 15671.60, writes/s: 4476.50, response time: 9.99ms (99%)
OLTP test statistics:
   queries performed:
       read:                            938224    -- 读总数
       write:                           268064    -- 写总数
       other:                           134032    -- 其他操作总数(SELECT、INSERT、UPDATE、DELETE之外的操作,例如COMMIT等)
       total:                           1340320    -- 全部总数
   transactions:                        67016  (1116.83 per sec.)    -- 总事务数(每秒事务数)
   deadlocks:                           0      (0.00 per sec.)    -- 发生死锁总数
   read/write requests:                 1206288 (20103.01 per sec.)    -- 读写总数(每秒读写次数)
   other operations:                    134032 (2233.67 per sec.)    -- 其他操作总数(每秒其他操作次数)

General statistics:    -- 一些统计结果
   total time:                          60.0053s    -- 总耗时
   total number of events:              67016    -- 共发生多少事务数
   total time taken by event execution: 479.8171s    -- 所有事务耗时相加(不考虑并行因素)
   response time:    -- 响应时长统计
        min:                                  4.27ms    -- 最小耗时
        avg:                                  7.16ms    -- 平均耗时
        max:                                 13.80ms    -- 最长耗时
        approx.  99 percentile:               9.88ms    -- 超过99%平均耗时

Threads fairness:
   events (avg/stddev):           8377.0000/44.33
   execution time (avg/stddev):   59.9771/0.00
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8月前
|
存储 运维 监控
mysql开启审计日志
mysql开启审计日志
330 0
|
11月前
|
Oracle 关系型数据库 MySQL
迁移MariaDB审计插件(Audit Plugin)到MySQL 5.7---发表到爱可生开源社区
Oracle的MySQL社区版本不带审计插件(Audit Plugin),要想使用审计功能,你可以用Enterprise的版本,不过这需要银子。业界还有一些GPL协议的审计插件,这里我们选择MariaDB的审计插件。
145 0
|
11月前
|
存储 SQL 监控
在MySQL社区版中也用上审计插件
在MySQL社区版中也用上审计插件
513 0
|
SQL 安全 网络协议
通过RDS MySQL SQL洞察和审计排查如何丢失数据?
最近遇到多次业务方,反馈数据写入成功,但是需要查询使用时,数据确找不到了,所以需要确认数据什么不见了?
通过RDS MySQL SQL洞察和审计排查如何丢失数据?
|
存储 SQL 监控
MySQL企业版之Audit(审计)初体验
MySQL企业版之Audit(审计)初体验
317 0
|
SQL 存储 监控
MySQL审计插件介绍
数据库审计功能主要将用户对数据库的各类操作行为记录审计日志,以便日后进行跟踪、查询、分析,以实现对用户操作的监控和审计。审计是一项非常重要的工作,也是企业数据安全体系的重要组成部分,等保评测中也要求有审计日志。对于 DBA 而言,数据库审计也极其重要,特别是发生人为事故后,审计日志便于我们进行责任追溯,问题查找。
404 0
MySQL审计插件介绍
|
关系型数据库 MySQL
【MySQL】MySQL审计操作记录
server_audit是一款内嵌在mariadb的审计插件,在mysql中同样适用,主要用于记录用户操作
235 0
|
SQL 存储 关系型数据库
MySQL——授权,角色和审计
MySQL——授权,角色和审计
|
SQL 数据采集 网络协议
MySQL数据库审计采集技术调研之Packetbeat,eBPF
在数据安全的重要性日益突出的今天,数据库审计是数据安全的重要组成部分。在数据库审计的过程中往往需要关注数据库操作行为和性能数据:需要知道数据库来源IP,数据库服务器IP/端口,数据库登录用户,操作数据库名称,表名称,SQL语句,执行时间和返回数据条数等。这些数据的获取在数据库内核实现无疑是最佳的方式,但是并非所有的数据库都支持审计插件。几乎所有的数据库都是C/S模式,客户端与数据库通过网络协议沟通,数据库的协议大部分也是公开的,所以一种更通用的数据库审计数据采集的方案,应该是通过“外围”的抓包方案,具体是通过分析网络协议来采集数据库的行为数据。
2700 0
MySQL数据库审计采集技术调研之Packetbeat,eBPF
|
存储 SQL 监控
MySQL企业版之Audit(审计)初体验
MySQL企业版之Audit(审计)初体验