V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Distributions
Ubuntu
Fedora
CentOS
中文资源站
网易开源镜像站
Mztck
V2EX  ›  Linux

mysql 开启审计功能( linux 版本)

  •  
  •   Mztck · 2015-06-25 15:11:47 +08:00 · 2628 次点击
    这是一个创建于 3234 天前的主题,其中的信息可能已经有所发展或是发生改变。

    创建一个用于存放连接日记的数据和表.

    creat database accesslog;
    CREATE TABLE accesslog.accesslog(idint(11)primary key auto_increment,timetimestamp,localnamevarchar(30),matchnamevarchar(30));
    创建用户权限.
    grant select on accesslog.* to root;
    注意用户必须对accesslog表具有insert权限.
    grant select on accesslog.* to user@'%';
    退出数据库或者重新开一个命令界面

    vi /etc /init.d /mysqld

    注:在[mysqld]下添加以下这段话.

    init-connect='insertinto accesslog.accesslog(id,time,localname,matchname)values(connection_id(),now(),user(),current_user());'

    保存退出回到数据库.
    select*from accesslog.accesslog where id= ;
    show processlist;

    3 条回复    2015-07-01 09:42:42 +08:00
    xfwduke
        1
    xfwduke  
       2015-06-26 19:01:35 +08:00
    1. init-connect 在短连接场景下是个巨坑
    2. accesslog 表如果是 MyISAM 引擎也是个坑, 可以参考 MyISAM 引擎行数限制以及机器文件大小限制
    3. 这玩意对有 super 权限的账号无效
    4. 开了这玩意, accesslog 出现任何问题, 都会导致无 super 权限账号无法连接
    5. 留着 root 这么个账号, 还开连接审计有点多此一举, 即使 root 账号有密码
    xfwduke
        2
    xfwduke  
       2015-06-26 19:15:14 +08:00
    另外再补充点
    开这个东西, 一般都是做行为审计分析, 要结合 mysql 的 slow query log 和 binary log

    依稀记得 mysql 的 slow query log 默认是没有 connect id 这个东西的, 新版本 mysql 有没有改不确认了. 如果没有就需要自己 patch 代码
    同样 binary log 也需要 connect id, 这个我记得好像是有的
    Mztck
        3
    Mztck  
    OP
       2015-07-01 09:42:42 +08:00
    是的。这种方法最多也就自己用来玩玩。想要真正打开需要准备许多东西。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2232 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 04:13 · PVG 12:13 · LAX 21:13 · JFK 00:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.