美文网首页
MariaDB server_audit 审计插件

MariaDB server_audit 审计插件

作者: 济南打工人 | 来源:发表于2019-06-19 16:55 被阅读0次

    具体安装步骤:
    1.使用SHOW VARIABLES LIKE 'plugin_dir'; 查出插件安装目录

    2.复制 mariadb-5.5.58-linux-x86_64/lib/plugin 下的 server_audit.so 到插件安装目录下如 /usr/local/mysql/lib/plugin 下,添加 +x 权限

    3.登录mysql执行安装插件操作
    mysql> INSTALL PLUGIN server_audit SONAME 'server_audit.so';

    查看变量开启设置情况,默认貌似都是关闭的:
    复制代码

    mysql> show variables like '%server_audit%';

    4.在 my.cnf 中添加如下配置,然后重启 mysqld:

    server_audit_events='QUERY_DDL,QUERY_DML,QUERY_DCL'
    server_audit_logging=on

    server_audit_file_path =/data/mysql/auditlogs/

    server_audit_file_rotate_size=200000000
    server_audit_file_rotations=200
    server_audit_file_rotate_now=ON
    server_audit_excl_users=root

    也可以动态开启审计功能:

    mysql> set global server_audit_logging=on;
    Query OK, 0 rows affected (0.00 sec)

    默认在mysql的数据目录下生成文件 server_audit.log ,日志格式为:

    可以看到,MariaDB的审计插件日志要比MySQL社区插件简洁许多。


    参数说明:(请参考: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:标识版本,用于开发测试

    复制代码


    卸载 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生效

    mysql> UNINSTALL PLUGIN server_audit;
    ERROR 1702 (HY000): Plugin 'server_audit' is force_plus_permanent and can not be unloaded

    值得注意的是,应该在server_audit插件被安装好,并且已经运行之后添加这些配置,否则过早在配置文件添加这个选项,会导致MySQL发生启动错误!

    相关文章

      网友评论

          本文标题:MariaDB server_audit 审计插件

          本文链接:https://www.haomeiwen.com/subject/hknkqctx.html