§ 审计
GreatSQL 支持审计功能,并将审计日志写入数据表中,并且设置审计日志入表规则,以便达到不同的审计需求。
审计功能仅记录当前节点审计信息,且在写表时不记录 Binlog 以避免数据会复制到从节点。在设置 sql_log_bin = 1
时只允许 SELECT, SHOW CREATE, SHOW FIELDS
查看审计表。
审计内容将包括操作账户、客户端ip、被操作的数据库对象、操作的完整语句、操作结果。
审计功能可实现以下几个作用:
- 对登录失败行为进行审计。
- 对数据库服务的启动和关闭进行审计。
- 允许基于数据库操作类型对数据库的操作进行审计,允许配置1个到多个的数据操作类型进行审计。
- 允许基于数据库对象对数据库的操作进行审计,允许配置针对1个到多个的数据库对象的操作进行审计。
- 允许基于数据库用户的操作进行审计,允许配置针对1个到多个的数据库用户的操作进行审计。
- 启用审计日志入表后,审计日志仍然可以同时存储一份在日志文件中。
§ 启用审计功能
-- 安装和启用审计插件
-- %basedir% 是 GreatSQL 二进制包安装目录
-- 如用 TAR 包安装时放在 /usr/local/GreatSQL-8.0.32-26-Linux-glibc2.28-x86_64/share 目录下
-- 或用 RPM 包安装时放在 /usr/share/mysql 目录下
greatsql> SOURCE %basedir%/share/install_audit_log.sql;
-- 卸载关闭审计插件
greatsql> SOURCE %basedir%/share/uninstall_audit_log.sql;
-- 启用审计入表特性
greatsql> SET GLOBAL audit_log_to_table = 1;
-- 查看审计信息
greatsql> select * from sys_audit.audit_log\G
...
name: Query
record: 1_17_2024-07-17T05:57:34
timestamp: 2024-07-17 13:58:34
command_class: create_table
connection_id: 40
status: 0
sqltext: create table t1(id int unsigned not null primary key, c1 varchar(20) not null)
user: root[root] @ localhost []
host: localhost
priv_user:
os_user:
ip:
db: greatsql
server_version:
os_version:
server_id: 1
timegmt: 1721195915424930
...
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
其中
name
审计的操作行为。常见的有Query(查询)、Quit(退出)、Connect(连接)、Init DB(选择某个数据库)。record
审计记录唯一标识,由 server_id + 当前节点递增序列号 + 时间戳 三部分组成。timestamp
审计记录时间。command_class
操作行为类型,例如 select(SELECT 查询)、init db(选择某个数据库)。connection_id
用户连接号。status
执行操作的状态,0 表示成功,非 0 为错误(通常是 SQL 执行错误,例如语法错误等)。sqltext
执行请求操作的 SQL 语句。user
执行操作的客户端用户名。host
客户端主机名。priv_user
用于检查权限的用户名。os_user
操作系统用户名。ip
用户登录 IP。db
执行操作时的当前数据库名。server_version
数据库版本。os_version
操作系统版本。server_id
数据库当前节点 server_id。timegmt
审计记录时间戳。
如果没启用审计入表特性,则审计日志存储在外部日志文件中,默认文件为 audit.log
,在 datadir
目录下,例如:
$ cat audit.log
...
<AUDIT_RECORD
NAME="Query"
RECORD="1_17_2024-07-17T05:57:34"
TIMESTAMP="2024-07-17 13:58:34"
COMMAND_CLASS="create_table"
CONNECTION_ID="40"
STATUS="0"
SQLTEXT="create table t1(id int unsigned not null primary key, c1 varchar(20) not null)"
USER="root[root] @ localhost []"
HOST="localhost"
OS_USER=""
IP=""
DB="greatsql"
/>
...
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
§ 新增变量说明
审计功能相关新增参数/选项有
greatsql> SHOW VARIABLES LIKE 'audit%';
+-----------------------------+----------------+
| Variable_name | Value |
+-----------------------------+----------------+
| audit_log_buffer_size | 1048576 |
| audit_log_enabled | 1 |
| audit_log_exclude_accounts | |
| audit_log_exclude_commands | |
| audit_log_exclude_databases | |
| audit_log_file | audit.log |
| audit_log_flush | OFF |
| audit_log_format | OLD |
| audit_log_handler | FILE |
| audit_log_include_accounts | |
| audit_log_include_commands | |
| audit_log_include_databases | |
| audit_log_policy | ALL |
| audit_log_rotate_on_size | 0 |
| audit_log_rotations | 0 |
| audit_log_strategy | ASYNCHRONOUS |
| audit_log_syslog_facility | LOG_USER |
| audit_log_syslog_ident | percona-audit |
| audit_log_syslog_priority | LOG_INFO |
| audit_log_to_table | 1 |
+-----------------------------+----------------+
21 rows in set (0.00 sec)
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
- audit_log_enabled
System Variable Name | audit_log_enabled |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | Boolean |
Default value | 1 |
Allowed values | 1(开), 0(关) |
审计日志功能总开关,设置是否启用该功能。
小贴士
执行 SOURCE install_audit_log.sql
安装审计插件后,会自动设置 audit_log_enabled = 1
启用审计功能。
也可以在不卸载审计插件的情况下,执行 SET GLOBAL audit_log_enabled = 0
临时禁用审计功能。
- audit_log_to_table
System Variable Name | audit_log_to_table |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | Boolean |
Default value | 0 |
Allowed values | 1(开), 0(关) |
审计日志是否写入到数据表开关,设置是否启用该特性。
- audit_log_strategy
System Variable Name | audit_log_strategy |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | ASYNCHRONOUS |
Allowed values | ASYNCHRONOUS, PERFORMANCE, SEMISYNCHRONOUS, SYNCHRONOUS |
设置审计日志存盘策略,当 audit_log_handler=FILE
时才有效,可选值有:
- ASYNCHRONOUS(默认),使用内存缓冲区存储日志,如果缓冲区已满,不丢弃消息。
- PERFORMANCE,使用内存缓冲区存储日志,如果缓冲区已满,则丢弃消息。
- SEMISYNCHRONOUS,直接记录到文件,不刷新&同步每个事件。
- SYNCHRONOUS,直接记录到文件,刷新并同步每个事件。
- audit_log_file
System Variable Name | audit_log_file |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | audit.log |
设置审计日志文件名,可以是包含 datadir
的相对路径或绝对路径。
- audit_log_flush
System Variable Name | audit_log_flush |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
Default value | OFF |
当此变量设置为ON时,审计日志文件会先关闭而后重新打开,这可用于手动切换日志文件。
- audit_log_buffer_size
System Variable Name | audit_log_buffer_size |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | Numeric |
Default value | 1 Mb |
设置用于存储审计日志记录的内存缓冲区大小,当 audit_log_strategy = ASYNCHRONOUS | PERFORMANCE
时,且当 audit_log_handler = FILE
时有效。
- audit_log_exclude_accounts
System Variable Name | audit_log_exclude_accounts |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
用于指定应用“按用户筛选”时的排除用户列表。该值可以是NULL,也可以是以逗号分隔的帐户列表,例如:user1@host,'user2'@'host',user3@%
。设置该参数后在新会话生效。如果设置了此变量,则不能同时设置 audit_log_include_accounts
,反之亦然。
- audit_log_exclude_commands
System Variable Name | audit_log_exclude_commands |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
用于指定应用“按SQL命令筛选”时的排除SQL命令列表。该值可以是NULL或逗号分隔的命令列表。如果设置了此变量,则不能同时设置 audit_log_include_commands
,反之亦然。
- audit_log_exclude_databases
System Variable Name | audit_log_exclude_databases |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
用于指定应用“按数据库筛选”时的排除数据库列表。该值可以是NULL或逗号分隔的数据库列表。如果设置了此变量,则不能同时设置 audit_log_include_databases
,反之亦然。
- audit_log_format
System Variable Name | audit_log_format |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | OLD |
Allowed values | OLD, NEW, CSV, JSON |
用于设置审计日志格式,支持四种格式:OLD/NEW/JSON/CSV
。其中OLD
和NEW
格式基于XML,前者将日志记录属性输出为XML属性,后者输出为XML标记。
- audit_log_include_accounts
System Variable Name | audit_log_include_accounts |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
用于指定应用“按用户筛选”时的包含用户列表。该值可以是NULL,也可以是以逗号分隔的帐户列表,例如:user1@host,'user2'@'host',user3@%
。如果设置了此变量,则不能同时设置 audit_log_exclude_accounts
,反之亦然。
- audit_log_include_commands
System Variable Name | audit_log_include_commands |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
用于指定应用“按SQL命令筛选”时的包含SQL命令列表。该值可以是NULL,也可以是以逗号分隔的SQL命令列表。如果设置了此变量,则不能同时设置 audit_log_exclude_commands
,反之亦然。
- audit_log_include_databases
System Variable Name | audit_log_include_databases |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
用于指定应用“按数据库筛选”时的包含数据库列表。该值可以是NULL,也可以是以逗号分隔的数据库列表。如果设置了此变量,则不能同时设置 audit_log_exclude_databases
,反之亦然。
- audit_log_policy
System Variable Name | audit_log_policy |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | Yes |
Data type | String |
Default value | ALL |
Allowed values | ALL, LOGINS, QUERIES, NONE |
设定审计日志应该记录哪些事件,可能的值为:
- ALL,将记录所有事件。
- LOGINS,只记录登录事件。
- QUERIES,只记录查询事件。
- NONE,不会记录任何事件。
- audit_log_rotate_on_size
System Variable Name | audit_log_rotate_on_size |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | Numeric |
Default value | 0 (don’t rotate the log file) |
设置审计日志文件的最大大小,单位:Byte。达到阈值后,将自动轮转审计日志,轮转后的新文件将自动增加相应的序号。当 audit_log_handler = FILE
时才有效。
- audit_log_rotations
System Variable Name | audit_log_rotations |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | Numeric |
Default value | 0 |
用于设置当 audit_log_rotate_on_size
设置为非零值时应保留多少个日志文件。当 audit_log_handler = FILE
时才有效。
- audit_log_handler
System Variable Name | audit_log_handler |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | FILE |
Allowed values | FILE, SYSLOG |
用于设置审计日志的写入的方式。如果设置为 FILE
,则写入由 audit_log_file
变量指定的文件中。如果设置为 SYSLOG
,则写入操作系统 SYSLOG
。
- audit_log_syslog_ident
System Variable Name | audit_log_syslog_ident |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | percona-audit |
用于设置SYSLOG的 ident
值,该变量的含义与syslog(3)手册 (opens new window)中描述的相应参数相同。
- audit_log_syslog_facility
System Variable Name | audit_log_syslog_facility |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | LOG_USER |
用于设置SYSLOG的 facility
值,该变量的含义与syslog(3)手册 (opens new window)中描述的相应参数相同。
- audit_log_syslog_priority
System Variable Name | audit_log_syslog_priority |
---|---|
Command-line | Yes |
Scope | Global |
Dynamic | No |
Data type | String |
Default value | LOG_INFO |
用于设置SYSLOG的 priority
值,该变量的含义与syslog(3)手册 (opens new window)中描述的相应参数相同。
§ 新增状态变量
- Audit_log_buffer_size_overflow
Option | Description |
---|---|
Scope | Global |
Data type | Numeric |
由于审计日志记录的大小大于 audit_log_buffer_size
变量而将其删除或直接写入文件的次数。
§ 应用案例
-- 启用审计入表特性
SET GLOBAL audit_log_to_table = 1;
-- 排除部分管理员角色用户的操作记录
-- 注意,这里只是排除,而不是禁止管理员的操作
SET PERSIST audit_log_exclude_accounts = 'root@localhost, admin@%, app_adm@%';
-- 重置排除名单,注意这里要设置 = NULL,而不是 = 'NULL'
SET PERSIST audit_log_exclude_accounts = NULL;
-- 查看审计日志(按时间倒序)
SELECT * FROM sys_audit.audit_log ORDER BY timestamp DESC LIMIT 10;
2
3
4
5
6
7
8
9
10
11
12
扫码关注微信公众号
← Clone 备份加密 国密加密 →