`

Oracle FGA审计

 
阅读更多

大家对trigger可能比较熟悉,但Oracle还有一个叫FGA的功能,它的作用和trigger类似,但功能更强大.它的全称是Fine-Grained Audit ,是Audit的一种特殊方式. 使用FGA只要调用Oracle的包DBMS_FGA.ADD_POLICY创建一些policy(审计策略)就行.每个policy只能针对一个表或视 图.建好策略后所以对表或视图的DML操作(select,insert,update,delete都可以记录到,当然也可以添加一些筛选条件只监测某 些特殊的操作.

补充:所谓审计就是记录你的任意操作,假如你的操作(执行DML语句)符合指定的条件,则你执行的sql语句,将被记录到sys用户下的一些表中,还会将你的其他信息,比如执行时间,用户名,通过什么工具,机器名等.FGA在oracle 9i中就有了,但在9i中只能审计select语句.从10g开始才能审计所有的DML操作

FGA与Triger的明显区别:

1.FGA使用自治的事务,即使DML操作被rollback了,它仍然照样执行不会rollback.而trigger是会被rollback的.

2.做更新操作时trigger可以记录更新前的旧值和更新后的新值,而FGA是不记录旧值.

1.包DBMS_FGA.ADD_POLICY的用法

创建审计策略的语法

DBMS_FGA.ADD_POLICY (

object_schema VARCHAR2, --schema的名字,表或视图的拥有者

object_name VARCHAR2, --对象名,表或视图的名字

policy_name VARCHAR2, --审计策略名字,它和数据库中其他对象一样,需要有一个不重复,唯一的名字

audit_condition VARCHAR2, --筛选条件比如可以选择哪些符合条件的操作被记录

audit_column VARCHAR2, --表中的某一列,可以只记录对表中某一列的操作.如果不指定表示审计所有的列

handler_schema VARCHAR2, --是下面的handler_module的拥有者,其实也只能是创建policy的用户,而上面的object_schema可以是任意用户

handler_module VARCHAR2,--可以是一个一个存储过程或函数,但监测到任何一条符合条件的操作时执行它.

enable BOOLEAN, --true 或false表示policy是开启或关闭状态,如果是false表示不进行审计

statement_types VARCHAR2, --表示哪些操作将被审计,可以填上select,insert,update,delete中的一个或几个

audit_trail BINARY_INTEGER IN DEFAULT,--有参数db,xml表示审计到的信息保存到数据库中或是以xml文件形式保存到磁盘上

audit_column_opts BINARY_INTEGER IN DEFAULT); --这 个选项其实只有在audt_column中指定了某列时才起作用.它有any_columns,all_columns两个选项假如表中有 eno,ename两列,并在audit_column中指定了这两列,那么选any_columns表示只要操作其中的任意一列都将被记录,而这里指定 all_columns的话是说只有一个sql语句同时操作了这两列才被记录

 

举例,假如创建表:create table temp(eno int,ename varchar2(30));针对这个表创建policy

每个策略只能针对一个表或视图,而一个表或视图可能对应多个策略.当表被删除时策略也随之默认被删除

BEGIN
SYS.DBMS_FGA.ADD_POLICY (
object_schema => 'ARWEN'
,object_name => 'TEMP'
,policy_name => 'FGA_TEMP'

,audit_condition => NULL
,audit_column => eno,ename
,handler_schema => null
,handler_module => null

,enable => TRUE
,statement_types =>'SELECT,INSERT,UPDATE,DELETE'
,audit_trail => SYS.DBMS_FGA.DB+SYS.DBMS_FGA.EXTENDED

--DBMS_FGA.DB表示记录将被保存到数据库中,DBMS_FGA.EXTENDED表示如果sql语句中带有绑定变量也会被记录下来.

--如果是这样选audit_trail => SYS.DBMS_FGA.DB表示不会记录绑定变量

--SYS.DBMS_FGA.DB+SYS.DBMS_FGA.EXTENDED改成SYS.DBMS_FGA.XML+SYS.DBMS_FGA.EXTENDED表示记录保存成xml文件

--xml文件所在目录可以通过SHOW PARAMETER AUDIT_FILE_DEST查看,如果要更改目录ALTER SYSTEM SET AUDIT_FILE_DEST = directory_path DEFERRED;

,audit_column_opts => SYS.DBMS_FGA.ALL_COLUMNS)
END;

 

查看创建好的policy对象和符合审计条件时被记录的操作

我们可以通过select * from dba_objects查看table,view等对象,类似的policy创建好后我们可以通过SELECT * FROM DBA_AUDIT_POLICIES来查看.

如果我们对表temp执行了DML操作,那些信息将会被操作到sys用户下的表中,Select* from sys.dba_fga_audit_trail可以查找到.(注意这只有前面设置将记录信息

保存到数据库才能这样查,如果保存到xml文件中可以Select *from V$XML_AUDIT_TRAIL)

 

2.删除审计策略,假如删除上面创建的策略

begin

SYS.DBMS_FGA.DROP_POLICY (

object_schema => 'ARWEN'

,object_name => 'TEMP'

,policy_name => 'FGA_TEMP'

);

end;

3.使用handler_module

 

假如你想在审计到某些操作时还进行进一步的处理,比如把信息写到自己创建的日志中,或者发送邮件通知相关人员.就要在创建policy时使用handler_module的功能,指定一个存储过程去做相应的处理.假如我创建一个存储过程temp_handler

CREATE OR REPLACE PROCEDURE temp_handler

( v_object_schema VARCHAR2

, v_object_name VARCHAR2

, v_policy_name VARCHAR2

)

IS

v_temp varchar2(30);

begin

null;

end temp_handler;

--这里的存储过程有点特殊,它必须带v_object_schema VARCHAR2, v_object_name VARCHAR2, v_policy_name VARCHAR2这三个参数才行,如果直接写一个一般的存储过程就会出错的.在policy中调用存储过程就这样 写

 

BEGIN
SYS.DBMS_FGA.ADD_POLICY (
object_schema => 'ARWEN'
,object_name => 'TEMP'
,policy_name => 'FGA_TEMP'

,audit_condition => NULL
,audit_column => eno,ename
,handler_schema =>'ARWEN' --注意此处的用户只能是创建此policy的用户,如果是其他用户名会出错的
,handler_module => 'TEMP_HANDLER'

,enable => TRUE
,statement_types =>'SELECT,INSERT,UPDATE,DELETE'
,audit_trail => SYS.DBMS_FGA.DB+SYS.DBMS_FGA.EXTENDED

,audit_column_opts => SYS.DBMS_FGA.ALL_COLUMNS)
END;

 

参考至:http://www.linuxidc.com/Linux/2013-06/86603.htm

如有错误,欢迎指正

邮箱:czmcj@163.com

分享到:
评论

相关推荐

    Oracle 细粒度审计(FGA)初步认识

    细粒度审计(FGA),是在Oracle 9i中引入的,能够记录SCN号和行级的更改以重建旧的数据,本文将详细介绍,需要的朋友可以参考下

    DQL DML细刻度审计.txt

    oracle细粒度审计(FGA) 是oracle提供的对表细粒度的级别的审计功能,可以捕获DML、SELECT等客户端发起的操作。

    fga.rar_FGA

    一个遗传算法的原代码,非常好用,只要传进参数即可使用

    oracle 12c 数据库 教程

    (六)细粒度审计(FGA) 71 (七)DBA 审计 73 (八)12c 审计的新特性 73 十、移动数据 76 (一)移动数据的整体架构 76 (二)目录对象 76 (三)使用 SQL*Loader 77 (四)数据泵 78 (五)外部表 80 十一、性能...

    截图软件FGA好用

    非常好用的截图软件,方便快速,值得拥有,大家一起进步

    基于FGA的VerilogHDL数字钟设计完整版.docx

    基于FGA的VerilogHDL数字钟设计完整版.docx基于FGA的VerilogHDL数字钟设计完整版.docx基于FGA的VerilogHDL数字钟设计完整版.docx基于FGA的VerilogHDL数字钟设计完整版.docx基于FGA的VerilogHDL数字钟设计完整版.docx...

    基于FGA的VerilogHDL数字钟设计完整版.pdf

    基于FGA的VerilogHDL数字钟设计完整版.pdf基于FGA的VerilogHDL数字钟设计完整版.pdf基于FGA的VerilogHDL数字钟设计完整版.pdf基于FGA的VerilogHDL数字钟设计完整版.pdf基于FGA的VerilogHDL数字钟设计完整版.pdf基于...

    Python-Python脚本生成fga格式的矢量字段可以直接导入到UnrealEngine4中

    Python脚本生成.fga格式的矢量字段,可以直接导入到Unreal Engine 4中

    oracle10g课堂练习I(2)

    Oracle Database 10 g :“g”代表网格 1-6 Oracle 数据库体系结构 1-8 数据库结构 1-9 Oracle 内存结构 1-10 进程结构 1-12 Oracle 实例管理 1-13 服务器进程和数据库缓冲区高速缓存 1-14 物理数据库结构 1-...

    狗粮.fga.json

    狗粮.fga.json

    OCPOCA认证考试指南全册:Oracle Database 11g(1Z0-051,1Z0-052,1Z0-053)--详细书签版(第2/2部分)

    6.6.4 细粒度审核(FGA) 201 6.7 本章知识点回顾 204 6.8 自测题 205 6.9 自测题答案 208 第Ⅱ部分 SQL 211 第7章 DDL和模式对象 213 7.1 分类主要的数据库对象 214 7.1.1 对象类型 214 7.1.2 命名模式对象 ...

    FGA:适用于FGO Android的自动战斗应用

    FGA:适用于FGO Android的自动战斗应用

    基于FGA的VerilogHDL数字钟设计 .docx

    基于FGA的VerilogHDL数字钟设计 .docx基于FGA的VerilogHDL数字钟设计 .docx基于FGA的VerilogHDL数字钟设计 .docx基于FGA的VerilogHDL数字钟设计 .docx基于FGA的VerilogHDL数字钟设计 .docx基于FGA的VerilogHDL数字钟...

    基于FGA的VerilogHDL数字钟设计.docx

    基于FGA的VerilogHDL数字钟设计.docx基于FGA的VerilogHDL数字钟设计.docx基于FGA的VerilogHDL数字钟设计.docx基于FGA的VerilogHDL数字钟设计.docx基于FGA的VerilogHDL数字钟设计.docx基于FGA的VerilogHDL数字钟设计....

    基于FGA的VerilogHDL数字钟设计.pdf

    基于FGA的VerilogHDL数字钟设计.pdf基于FGA的VerilogHDL数字钟设计.pdf基于FGA的VerilogHDL数字钟设计.pdf基于FGA的VerilogHDL数字钟设计.pdf基于FGA的VerilogHDL数字钟设计.pdf基于FGA的VerilogHDL数字钟设计.pdf...

    基于FGA的VerilogHDL数字钟设计 .pdf

    基于FGA的VerilogHDL数字钟设计 .pdf基于FGA的VerilogHDL数字钟设计 .pdf基于FGA的VerilogHDL数字钟设计 .pdf基于FGA的VerilogHDL数字钟设计 .pdf基于FGA的VerilogHDL数字钟设计 .pdf基于FGA的VerilogHDL数字钟设计 ...

Global site tag (gtag.js) - Google Analytics