天天看點

mysql審計一,審計安裝:二,開啟審計後對mysql進行壓力測試:

環境: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、審計日志:

mysql審計一,審計安裝:二,開啟審計後對mysql進行壓力測試:

二,開啟審計後對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           

繼續閱讀