当前位置:  数据库>oracle

Oracle 11g 监控单张表的增删改查操作

    来源: 互联网  发布时间:2017-06-11

    本文导语: 前言:线上Oracle数据库有张表的数据有些乱,根据应用db的log和应用的log也没有检查出来谁修改了,所以决定把这张单表做个详细的insert、update、delete监控。 一:使用数据库自带的审计功能1,查看审计功能是否启动SQL> show paramet...

前言:
线上Oracle数据库有张表的数据有些乱,根据应用db的log和应用的log也没有检查出来谁修改了,所以决定把这张单表做个详细的insert、update、delete监控。

一:使用数据库自带的审计功能
1,查看审计功能是否启动
SQL> show parameter audit                                                                                                                                                                     


NAME    TYPE VALUE
------------------------------------ ----------- ------------------------------
audit_file_dest    string /oracle/app/oracle/admin/power
des/adump
audit_sys_operations    boolean FALSE
audit_syslog_level    string
audit_trail    string NONE
SQL>
没有开启审计功能,需要自己去开启一下。


2,开启审计功能
需要用sysdba,注意audit_trail要为DB_EXTENDED才记录执行的具体语句...
alter system set audit_sys_operations=TRUE scope=spfile;
SQL> alter system set audit_sys_operations=TRUE scope=spfile;                                                                                                                                 
                                                                                                                                                                                             
System altered.


SQL>

再次查看审计功能是否启动
SQL> show parameter audit;                                                                                                                                                                   


NAME    TYPE VALUE
------------------------------------ ----------- ------------------------------
audit_file_dest    string /oracle/app/oracle/admin/power
des/adump
audit_sys_operations    boolean FALSE
audit_syslog_level    string
audit_trail    string NONE
SQL>         


需要重启实例才能看到状态。


3,关闭审计功能
SQL> alter system set audit_trail = none scope=spfile;


4,针对某张表的审计功能
AUDIT UPDATE,DELETE,INSERT ON T_TEST by access;


5,对该张表进行各种DML操作测试


6,查询审计的信息
select EXTENDED_TIMESTAMP,SESSION_ID,SQL_TEXT from DBA_COMMON_AUDIT_TRAIL ORDER BY EXTENDED_TIMESTAMP DESC;


二,采用触发器
        看到线上数据库load比以前增加蛮多的,为了单张表的监控开启审计比较消耗资源,有些不划算,所以可以采用另外一种办法来做,就是在表上建立触发器。

1,先建立建立测试表:
查看已经建立的表 aaa_test与trig_sql。
SQL> describe plas.aaa_test;                                                                                                                                                                 
 Name  Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID    NUMBER
 NAME    VARCHAR2(100)
 LOGIN_TIME    DATE


SQL>
SQL> describe plas.trig_sql;                                                                                                                                                                 
 Name  Null?    Type
 ----------------------------------------- -------- ----------------------------
 LT    DATE
 SID    NUMBER
 SERIAL#    NUMBER
 USERNAME    VARCHAR2(30)
 OSUSER    VARCHAR2(64)
 MACHINE    VARCHAR2(32)
 TERMINAL    VARCHAR2(16)
 PROGRAM    VARCHAR2(64)
 SQLTEXT    VARCHAR2(2000)
 STATUS    VARCHAR2(30)
 CLIENT_IP    VARCHAR2(60)


SQL>


2,并且在 trig_sql表上面添加索引:
 create index  idx_time on plas.trig_sql (LT);
 
3,建立触发器
create or replace trigger pri_test
  after insert or update or delete on plas.aaa_test
DECLARE
  PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
  IF inserting THEN
    INSERT INTO plas.trig_sql
        select sysdate,s.SID, s.SERIAL#, s.USERNAME, s.OSUSER,
              s.MACHINE, s.TERMINAL, s.PROGRAM, q.sql_text line,
              'INSERT',
              sys_context('userenv','ip_address')
          from v$sql q, v$session s
        where s.audsid=(select userenv('SESSIONID') from dual)
          and s.prev_sql_addr=q.address
          AND s.PREV_HASH_VALUE = q.hash_value;
    COMMIT;
  ELSIF deleting  then
      INSERT INTO plas.trig_sql
          select sysdate,s.SID, s.SERIAL#, s.USERNAME, s.OSUSER,
                      s.MACHINE, s.TERMINAL, s.PROGRAM, q.sql_text line,
                      'DELETE',
                      sys_context('userenv','ip_address')
            from v$sql q, v$session s
            where s.audsid=(select userenv('SESSIONID') from dual)
            and s.prev_sql_addr=q.address
            AND s.PREV_HASH_VALUE = q.hash_value;
    COMMIT;
  ELSIF updating then
    INSERT INTO plas.trig_sql
        select sysdate,s.SID, s.SERIAL#, s.USERNAME, s.OSUSER,
                    s.MACHINE, s.TERMINAL, s.PROGRAM, q.sql_text line,
                    'UPDATE',
                    sys_context('userenv','ip_address')
          from v$sql q, v$session s
          where s.audsid=(select userenv('SESSIONID') from dual)
          and s.prev_sql_addr=q.address
          AND s.PREV_HASH_VALUE = q.hash_value;
    COMMIT;
  END IF;
END;

4,开始进行数据操作测试:
          insert into plas.aaa_test1 select 2,'tom',sysdate from dual;
          update plas.aaa_test1 a set a.name='tom_up' where a.id=2;
  update plas.aaa_test a set a.name='tom_up1' where a.id=1;
......
          commit;


5,去查看表记录,会发现如下
SQL> select * from plas.trig_sql;
LT                SID    SERIAL# USERNAME                      OSUSER                                                          MACHINE                          TERMINAL        PROGRAM                                                          SQLTEXT                                                                          STATUS                        CLIENT_IP
----------- ---------- ---------- ------------------------------ ---------------------------------------------------------------- -------------------------------- ---------------- ---------------------------------------------------------------- -------------------------------------------------------------------------------- ------------------------------ ------------------------------------------------------------
2014/10/29        1273      33297 POWERDESK                      Administrator                                                    WORKGROUPWIN-18P5Q5AREH9        WIN-18P5Q5AREH9  plsqldev.exe                                                    begin :id := sys.dbms_transaction.local_transaction_id; end;                    INSERT                        192.168.170.180
2014/10/29        1273      33297 POWERDESK                      Administrator                                                    WORKGROUPWIN-18P5Q5AREH9        WIN-18P5Q5AREH9  plsqldev.exe                                                    begin :id := sys.dbms_transaction.local_transaction_id; end;                    DELETE                        192.168.170.180
2014/10/29        1273      33297 POWERDESK                      Administrator                                                    WORKGROUPWIN-18P5Q5AREH9        WIN-18P5Q5AREH9  plsqldev.exe                                                    begin :id := sys.dbms_transaction.local_transaction_id; end;                    INSERT                        192.168.170.180
2014/10/29        1352      40155 POWERDESK                      Administrator                                                    WORKGROUPWIN-18P5Q5AREH9        WIN-18P5Q5AREH9  plsqldev.exe                                                    begin :id := sys.dbms_transaction.local_transaction_id; end;                    INSERT                        192.168.170.180
2014/10/29        1273      33297 POWERDESK                      Administrator                                                    WORKGROUPWIN-18P5Q5AREH9        WIN-18P5Q5AREH9  plsqldev.exe                                                    begin :id := sys.dbms_transaction.local_transaction_id; end;                    UPDATE                        192.168.170.180
2014/10/29        1273      33297 POWERDESK                      Administrator                                                    WORKGROUPWIN-18P5Q5AREH9        WIN-18P5Q5AREH9  plsqldev.exe                                                    begin :id := sys.dbms_transaction.local_transaction_id; end;                    UPDATE                        192.168.170.110
2014/10/29          25      39527 SYS                            oracle                                                          localhost.localdomain            pts/1            sqlplus@localhost.localdomain (TNS V1-V3)                        update plas.aaa_test a set a.name='tom_update' where id=2                        UPDATE                       
2014/10/29          25      39527 SYS                            oracle                                                          localhost.localdomain            pts/1            sqlplus@localhost.localdomain (TNS V1-V3)                        update plas.aaa_test a set a.name='tom_update3' where id=3                      UPDATE                       
8 rows selected


SQL>


PS:看到SQLTEXT有些都为  begin :id := sys.dbms_transaction.local_transaction_id; end; 的,是因为我执行的insert、delete、update语句在plsqldev.exe客户端执行的,所以没有记录下执行的sql语句。而有些通过sqlplus@localhost.localdomain (TNS V1-V3)客户端连接执行的,会记录下执行过的update语句。


6,统计下当前都有哪些用户以及ip执行了dml操作。
SQL> select username,client_ip from plas.trig_sql group by username,client_ip;
USERNAME                      CLIENT_IP
------------------------------ ------------------------------------------------------------
PLAS                          192.168.170.180
DESKER                        192.168.170.110


SQL>

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • ORACLE日期相关操作
  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • Oracle终于涉入支持Linux操作系统了
  • Linux平台下Oracle的操作
  • linux c 怎样利用pro*c/c++操作 win2000 下 oracle 谢谢
  • Window客户端通过ADO是否能够连接和操作Unix平台下的Oracle数据库?
  • Oracle将字符编码从GBK转到UTF8,如何操作比较稳妥?
  • 如何设定linux red hat 9的oracle9,让window的电脑可以操作数据库
  • linux oracle数据库删除操作指南
  • Linux环境中Oracle数据导入与导出备份操作
  • Oracle中操作分页 iis7站长之家
  • oracle的plsql里有没有位操作的功能
  • fedora core5 (FC5) 下面不能装 Oracle 10g 么? (检查操作系统就通不过啊,晕)
  • Linux操作系统下Oracle数据库多实例启动方式及修改内存
  • 怎样在c语言的代码里内嵌的操作oracle数据库,各位大虾谢谢了
  • 一个关于JAVA操作oracle数据库时UPDATE权限的问题
  • Oracle中操作分页
  • Oracle 数据库操作技巧集
  • secureCRT远程连接服务器操作oracle数据库出现的问题
  • 请教各位:JAVA操作ORACLE的问题 急!!!
  • 学习登录oracle数据库时常用的操作命令
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,