oracle审计
Orcale审计机制研究
1. 设置审计
1.1. 查看审计状态
SQL>conn /as sysdba;
已连接
SQL>show parameters audit_trail;
NAME TYPE VALUE
------------------------- ------------------------
audit_trail string NONE
1.2. 确认审计相关的表是否已经安装
首先查看审计相关的表是否已安装,执行如下命令:
SQLPLUS> connect / AS SYSDBA
SQLPLUS> select * from sys.aud$; --没有记录返回
SQLPLUS> select * from dba_audit_trail; --没有记录返回
如果做上述查询的时候发现表不存在,说明审计相关的表还没有安装,需要安装。
安装执行如下命令:
SQLPLUS> connect / as sysdba
SQLPLUS> @$ORACLE_HOME/rdbms/admin/cataudit.sql
审计表安装在SYSTEM表空间。所以要确保SYSTEM表空间又足够的空间存放审计信息。
1.3. 修改状态,激活审计(用户SYS)
激活审计执行如下命令:
SQL> alter system set audit_sys_operations=true scope=spfile;
System altered
SQL> alter system set audit_trail=DB,EXTENDED scope=spfile;
System altered
注: l DB/TRUE:启动审计功能,并且把审计结果存放在数据库的 SYS.AUD$ 表中
l OS:启动审计功能,并把审计结果存放在操作系统的审计信息中
l EXTENDED:具有DB/TRUE的功能,另外填写AUD$的SQLBIND和SQLTEXT字段
l NONE/FALSE:关闭审计功能
重启数据库实例:
SQL> startup force;
ORACLE 例程已经启动。
1.4. 再查看状态(用户SYS)
SQL> show parameter audit;
NAME TYPE VALUE
------------------------- ------------------------
audit_trail string DB, EXTENDED
1.5. 建立测试表(用户TPLATFORM)
建立测试表(T_AUDIT_DEMO)准备进行审计测试:
Create Table T_AUDIT_DEMO
(
CID INT NOT NULL,
CNAME VARCHAR2(20) NULL,
ENAME VARCHAR2(20) NULL,
CONSTRAINT PK_T_AUDIT_DEMO PRIMARY KEY (CID)
);
表已创建
1.6. 设置审计
对用户TPLATFORM下的表进行审计操作:
SQL> conn /as sysdba;
已连接
SQL> audit select table by TPLATFORM by access; //设置审计查询
审计已成功
SQL> audit update table by TPLATFORM by access; //设置审计更新
审计已成功
SQL> audit insert table by TPLATFORM by access ; //设置审计添加
审计已成功
SQL> audit DELETE table by TPLATFORM by access; //设置审计删除
审计已成功
(如果在命令中添加by TPLATFORM则只对TPLATFORM的操作进行审计,否则对所以用户操作进行审计)
2. 使用审计查看
2.1. 进行审计测试(用户SYS、TPLATFORM)
添加表数据准备测试审计:
INSERT INTO T_AUDIT_DEMO VALUES(1,'曾勋','ZENG XUN');
INSERT INTO T_AUDIT_DEMO VALUES(2,'翁黎明','WENG LI MING');
INSERT INTO T_AUDIT_DEMO VALUES(3,'刘帝勇','LIU DI YONG');
查询表数据准备测试审计:
SELECT * FROM T_AUDIT_DEMO WHERE CID < 3
删除表数据准备测试审计:
DELETE FROM T_AUDIT_DEMO WHERE CID = 3;
提交
commit;
SQL> select action_name,sql_text from sys.aud$ where OBJ_NAME = 'T_AUDIT_DEMO';
dba_audit_trail的关键字段:
OBJ$CREATOR 操作对象
NTIMESTAMP# 操作提交时间
OBJ$NAME 表名
ACTION 操作类型(对应audit_action表, audit_action表中有两个字段action,name,分别为操作类型,操作类型名称)
SQLTEXT 执行的sql语句
3. 性能
由于审计相关的表aud$存放在SYSTEM表空间,因此为了不影响系统的性能,保护SYSTEM表空间,最好移动到其他的表空间上。可以使用下面的语句来进行移动:
实际上sys.aud$表上包含了两个lob字段(sqlbind, SQLTEXT),并不是简单的move table就可以。
下面是具体的过程:
SQL>alter table aud$ move tablespace 表空间名;
SQL>alter table sys.aud$ move lob(sqlbind) store as( tablespace 表空间名);
SQL>alter table sys.aud$ move lob(SQLTEXT) store as( tablespace表空间名);
SQL>alter index I_aud1 rebuild online tablespace 表空间名;
SQL> alter table audit$ move tablespace 表空间名;
SQL> alter index i_audit rebuild online tablespace 表空间名;
SQL> alter table audit_actions move tablespace 表空间名;
SQL> alter index i_audit_actions rebuild online tablespace 表空间名;
4. 运维
可能随着时间越久,信息量就会越大,需要定期进行删除以前的数据(如:3个月).
oracle审计的更多相关文章
- [转]ORACLE 审计功能
审计是对选定的用户动作的监控和记录,通常用于: u 审查可疑的活动.例如:数据被非授权用户所删除,此时安全管理员可决定对该 数据库的所有连接进行审计,以及对数据库的所有表的成功地或不 ...
- 转-利用Oracle审计功能来监测试环境的变化
http://blog.csdn.net/luowangjun/article/details/5627102利用Oracle审计功能来监测试环境的变化 做过测试的人都应该会碰到这样的情况:测试发现的 ...
- 转--Oracle 审计和测试操作
http://blog.itpub.net/21605631/viewspace-759640/转 Oracle 审计和测试操作 :: 分类: Linux 1.1 相关参数 AUDIT_SYS_OPE ...
- oracle 审计功能
Oracle 11g推出了审计功能,但这个功能会针对很多操作都产生审计文件.aud,日积月累下来这些文件也很多,默认情况下,系统为了节省资源,减少I/0操作,其审计功能是关闭的 一.审计功能关闭 1. ...
- ORACLE审计小结
ORACLE审计小结 1.什么是审计 审计(Audit)用于监视用户所执行的数据库操作,并且Oracle会将审计跟踪结果存放到OS文件(默认位置为$ORACLE_BASE/admin/$ORACLE_ ...
- oracle审计表迁移
============ oracle审计表迁移到新的表空间 ============ 前言 oracle数据库开启审计功能后会占用大量的SYSTEM系统表空间,要么定时对审计表进行清理,要么对系统表 ...
- Oracle 审计文件
Oracle审计功能: Oracle11g推出了审计功能,但这个功能会针对很多操作都产生审计文件.aud,日积月累下来这些文件也很多,默认情况下,系统为了节省资源,减少I/0操作,其审计功能是关闭的 ...
- oracle审计详解-转
http://blog.chinaunix.net/u2/66903/showart_2082884.htmlOracle使用大量不同的审计方法来监控使用何种权限,以及访问哪些对象.审计不会防止使用这 ...
- [转]oracle审计详解
http://blog.chinaunix.net/u2/66903/showart_2082884.html Oracle使用大量不同的审计方法来监控使用何种权限,以及访问哪些对象.审计不会防止使用 ...
随机推荐
- phpmailer邮件类下载(转)
PHPMailer是一个用于发送电子邮件的PHP函数包.它提供的功能包括:*.在发送邮时指定多个收件人,抄送地址,暗送地址和回复地址*.支持多种邮件编码包括:8bit,base64,binary和qu ...
- 自定义 textField 的清除 button
UIButton *clearButton = [self.textField valueForKey:@"_clearButton"]; [clearButton setImag ...
- xcode升级或者重新安装后不能编译的解决方法
昨天由于xcode有一些问题,因此进行了重新安装,结果安装好后进行编译,没有进行任何改动的代码出现了两个fatal error 查看错误信息为什么的header has allready build, ...
- Java基础知识强化16:深入分析Java线程中断机制
1.Thread.interrupt真的能中断线程吗? 在平时的开发过程中,相信都会使用到多线程,在使用多线程时,大家也会遇到各种各样的问题,今天我们就来说说一个多线程的问题——线程中断. ...
- Weex 学习教程
一.环境搭建 1.安装Node,官网下载(http://nodejs.org/) 2.查看npm安装版本,终端输入:npm -v版本不能低于2.15.1 3.安装weex-toolkit,终端输入:n ...
- eclipse下:selenium+python自动化之Chrome driver
1.下载chromedriver.exe文件: 2.下载的chromedriver.exe文件放置在chrome的安装目录下XXX\Chrome\Application\ ; 3.设置path环境变量 ...
- html multiple select option 分组
普通html方式展示<select name="viewType" style="width: 100%;height: 300px;" multiple ...
- Xcode4.4中,代码无法高亮、无法自动补全
1.代码无法高亮显示:2.代码不能自动补全,或者给出提示建议:(当然这个补全的功能我在设置当中是打开的状态)3.新建一个项目,代码还是依然没有高亮显示,但是有补全功能:4.然后我就在网络上搜索了相关的 ...
- Wpf自定义路由事件
创建自定义路由事件大体可以分为三个步骤: ①声明并注册路由事件. ②为路由事件添加CLR事件包装. ③创建可以激发路由事件的方法. 以ButtonBase类中代码为例展示这3个步骤: public a ...
- javascript基础学习(九)
javascript之基本包装类型 学习要点: 基本包装类型概述 Boolean类型 Number类型 String类型 一.基本包装类型概述 为了便于操作基本类型值,提供了3种特殊的引用类型:Boo ...