利用Oracle审计功能记录数据库操作

合集下载

利用Oracle审计功能记录数据库操作

利用Oracle审计功能记录数据库操作

1、什么是审计审计Audit用于监视用户所执行的数据库操作;并且Oracle会将审计跟踪结果存放到OS文件默认位置为$ORACLE_BASE/admin/$ORACLE_SID/adump/或数据库存储在system表空间中的SYS.AUD$表中;可通过视图dba_audit_trail查看中..默认情况下审计是没有开启的..不管你是否打开数据库的审计功能;以下这些操作系统会强制记录:用管理员权限连接Instance;启动数据库;关闭数据库..2、和审计相关的两个主要参数Audit_sys_operations:默认为false;当设置为true时;所有sys用户包括以sysdba;sysoper身份登录的用户的操作都会被记录;audit trail不会写在aud$表中;这个很好理解;如果数据库还未启动aud$不可用;那么像conn /as sysdba这样的连接信息;只能记录在其它地方..如果是windows平台;audti trail会记录在windows的事件管理中;如果是linux/unix平台则会记录在audit_file_dest参数指定的文件中..Audit_trail:None:是默认值;不做审计;DB:将audit trail 记录在数据库的审计相关表中;如aud$;审计的结果只有连接信息;DB_Extended:这样审计结果里面除了连接信息还包含了当时执行的具体语句;OS:将audit trail 记录在操作系统文件中;文件名由audit_file_dest 参数指定;XML:10g里新增的..注:这两个参数是static参数;需要重新启动数据库才能生效..3、审计级别当开启审计功能后;可在三个级别对数据库进行审计:Statement语句、Privilege权限、object对象..Statement:按语句来审计;比如audit table 会审计数据库中所有的create table;drop table;truncate table语句;alter session by cmy会审计cmy用户所有的数据库连接..Privilege:按权限来审计;当用户使用了该权限则被审计;如执行grant select any table to a;当执行了audit select any table语句后;当用户a 访问了用户b的表时如select from b.t会用到select any table权限;故会被审计..注意用户是自己表的所有者;所以用户访问自己的表不会被审计..Object:按对象审计;只审计on关键字指定对象的相关操作;如aduitalter;delete;drop;insert on cmy.t by scott; 这里会对cmy用户的t 表进行审计;但同时使用了by子句;所以只会对scott用户发起的操作进行审计..注意Oracle没有提供对schema中所有对象的审计功能;只能一个一个对象审计;对于后面创建的对象;Oracle则提供on default子句来实现自动审计;比如执行audit drop on default by access;后; 对于随后创建的对象的drop操作都会审计..但这个default会对之后创建的所有数据库对象有效;似乎没办法指定只对某个用户创建的对象有效;想比trigger可以对schema的DDL进行“审计”;这个功能稍显不足..4、审计的一些其他选项by access / by session:by access 每一个被审计的操作都会生成一条audit trail..by session 一个会话里面同类型的操作只会生成一条audit trail;默认为by session..whenever not successful:whenever successful 操作成功dba_audit_trail中returncode字段为0 才审计;whenever not successful 反之..省略该子句的话;不管操作成功与否都会审计..5、和审计相关的视图dba_audit_trail:保存所有的audit trail;实际上它只是一个基于aud$的视图..其它的视图dba_audit_session;dba_audit_object;dba_audit_statement都只是dba_audit_trail的一个子集..dba_stmt_audit_opts:可以用来查看statement审计级别的audit options;即数据库设置过哪些statement级别的审计..dba_obj_audit_opts;dba_priv_audit_opts视图功能与之类似all_def_audit_opts:用来查看数据库用on default子句设置了哪些默认对象审计..6、取消审计将对应审计语句的audit改为noaudit即可;如audit session whenever successful对应的取消审计语句为noaudit session whenever successful;8、实例讲解8.1、激活审计sqlplus / as sysdbaSQL> show parameter auditNAME TYPE VALUE------------------------------------ -----------------------------------------audit_file_dest string/u01/app/oracle/admin/ORCL/adumpaudit_sys_operations boolean FALSEaudit_syslog_level stringaudit_trail string NONESQL> alter system set audit_sys_operations=TRUE scope=spfile;--审计管理用户以sysdba/sysoper角色登陆SQL> alter system set audit_trail=db_extended scope=spfile;SQL> startup force;SQL> show parameter auditNAME TYPE VALUE------------------------------------ -----------------------------------------audit_file_dest string/u01/app/oracle/admin/ORCL/adumpaudit_sys_operations boolean TRUEaudit_syslog_level stringaudit_trail string DB_EXTENDED 8.2、开始审计sqlplus / as sysdba--记录对一个表的所有操作SQL> audit all on t_test;SQL> conn u_testSQL> select from t_test;SQL> insert into u_test.t_test c2;c5 values 'test1';'2';SQL> commit;SQL> delete from u_test.t_test;SQL> commit;SQL> conn /as sysdbaSQL> selectOS_USERNAME;username;USERHOST;TERMINAL;TIMESTAMP;OWNER;obj_name ;ACTION_NAME;sessionid;os_process;sql_bind;sql_text fromdba_audit_trail;sql> audit select table by u_test by access;如果在命令后面添加by user则只对user的操作进行审计;如果省去by 用户;则对系统中所有的用户进行审计不包含sys用户.例:AUDIT DELETE ANY TABLE; --审计删除表的操作AUDIT DELETE ANY TABLE WHENEVER NOT SUCCESSFUL; --只审计删除失败的情况AUDIT DELETE ANY TABLE WHENEVER SUCCESSFUL; --只审计删除成功的情况AUDIT DELETE;UPDATE;INSERT ON user.table by test; --审计test 用户对表user.table的delete;update;insert操作8.3、撤销审计SQL> noaudit all on t_test;9、审计语句多层环境下的审计:appserve-应用服务器;jackson-clientAUDIT SELECT TABLE BY appserve ON BEHALF OF jackson;审计连接或断开连接:AUDIT SESSION;AUDIT SESSION BY jeff; lori; -- 指定用户审计权限使用该权限才能执行的操作:AUDIT DELETE ANY TABLE BY ACCESS WHENEVER NOT SUCCESSFUL;AUDIT DELETE ANY TABLE;AUDIT SELECT TABLE; INSERT TABLE; DELETE TABLE; EXECUTE PROCEDURE BY ACCESS WHENEVER NOT SUCCESSFUL;对象审计:AUDIT DELETE ON jeff.emp;AUDIT SELECT; INSERT; DELETE ON jward.dept BY ACCESS WHENEVER SUCCESSFUL;取消审计:NOAUDIT session;NOAUDIT session BY jeff; lori;NOAUDIT DELETE ANY TABLE;NOAUDIT SELECT TABLE; INSERT TABLE; DELETE TABLE;EXECUTE PROCEDURE; NOAUDIT ALL; -- 取消所有statement审计NOAUDIT ALL PRIVILEGES; -- 取消所有权限审计NOAUDIT ALL ON DEFAULT; -- 取消所有对象审计10、清除审计信息DELETE FROM SYS.AUD$;DELETE FROM SYS.AUD$ WHERE obj$name='EMP';11、审计视图STMT_AUDIT_OPTION_MAP -- 审计选项类型代码AUDIT_ACTIONS -- action代码ALL_DEF_AUDIT_OPTS -- 对象创建时默认的对象审计选项DBA_STMT_AUDIT_OPTS -- 当前数据库系统审计选项DBA_PRIV_AUDIT_OPTS -- 权限审计选项DBA_OBJ_AUDIT_OPTSUSER_OBJ_AUDIT_OPTS; -- 对象审计选项DBA_AUDIT_TRAILUSER_AUDIT_TRAIL -- 审计记录DBA_AUDIT_OBJECTUSER_AUDIT_OBJECT -- 审计对象列表DBA_AUDIT_SESSIONUSER_AUDIT_SESSION -- session审计DBA_AUDIT_STATEMENTUSER_AUDIT_STATEMENT -- 语句审计DBA_AUDIT_EXISTS -- 使用BY AUDIT NOT EXISTS选项的审计DBA_AUDIT_POLICIES -- 审计POLICIESDBA_COMMON_AUDIT_TRAIL -- 标准审计+精细审计12、将审计结果表从system表空间里移动到别的表空间上实际上sys.aud$表上包含了两个lob字段;并不是简单的move table就可以..下面是具体的过程:alter table sys.aud$ move tablespace users;alter table sys.aud$ move lobsqlbind store as tablespace USERS; alter table sys.aud$ move lobSQLTEXT store as tablespace USERS; alter index sys.I_AUD1 rebuild tablespace u。

查询oracle数据库审计信息的方法

查询oracle数据库审计信息的方法

查询oracle数据库审计信息的方法查询Oracle数据库审计信息的方法1. 概述Oracle数据库的审计功能是一种重要的安全功能,可以帮助管理员监控数据库中的活动,并跟踪和记录对数据库的访问和操作。

审计信息可以用于检测并响应数据库中的潜在安全威胁,同时也可以用于满足合规性要求。

本文将介绍查询Oracle数据库审计信息的方法,帮助管理员获取有关数据库活动的详细报告和分析。

2. 启用审计功能在开始查询审计信息之前,首先需要确保已经启用了Oracle数据库的审计功能。

审计功能通过以下步骤来启用:1) 以sysdba或sysoper权限连接到数据库。

2) 运行以下命令来启用审计功能:ALTER SYSTEM SET audit_trail = db SCOPE=spfile;3) 重启数据库实例使更改生效:SHUTDOWN IMMEDIATE;STARTUP;启用审计功能后,数据库将开始记录指定的审计信息。

3. 查询审计信息要查询Oracle数据库中的审计信息,可以使用以下方法之一:1) 使用Oracle自带的审计视图Oracle提供了一系列的审计视图,用于访问和查询审计信息。

一些常用的审计视图包括:DBA_AUDIT_TRAIL,DBA_COMMON_AUDIT_TRAIL,DBA_FGA_AUDIT_TRAIL等。

管理员可以根据自己的需要选择适当的视图,并使用标准的SQL查询语句来检索审计信息。

可以查询DBA_AUDIT_TRAIL视图来获取数据库级别的审计信息: SELECT * FROM DBA_AUDIT_TRAIL;或者可以查询DBA_COMMON_AUDIT_TRAIL视图来获取通用的审计信息:SELECT * FROM DBA_COMMON_AUDIT_TRAIL;2) 使用审计报告工具除了使用审计视图,还可以使用一些第三方的审计报告工具来查询和分析审计信息。

这些工具通常提供更直观和丰富的报告和分析功能,可以帮助管理员更方便地浏览和理解审计信息。

oracle 审计日志 设置规则

oracle 审计日志 设置规则

oracle 审计日志设置规则Oracle 审计日志设置规则在使用Oracle数据库的过程中,审计日志是十分重要的安全措施之一。

它可以记录所有数据库中的操作,包括用户登录、数据更改、数据访问等。

通过设置审计日志规则,您可以更好地监控和保护数据库的安全性。

以下是一些设置Oracle审计日志规则的重要步骤:1. 定义审计目标:首先,您需要明确设置审计日志的目标。

考虑您需要监控的数据库操作类型,比如是否需要审计所有用户的登录、所有的数据更新操作等。

2. 创建审计策略:在Oracle数据库中,您可以使用`DBMS_AUDIT_MGMT` 包来创建审计策略。

通过指定数据库对象和操作类型,您可以定义审计规则。

例如,您可以设置审计规则仅审计某个特定用户的操作,并排除其他用户。

3. 启用审计选项:在设置好审计规则后,您需要启用审计选项以开始记录审计日志。

可以通过以下步骤启用审计选项:- 使用`DBMS_AUDIT_MGMT.SET_AUDIT_TRAIL_PROPERTY`过程,将审计日志输出到特定的目标文件或操作系统日志中。

- 使用`DBMS_AUDIT_MGMT.ENABLE_AUDIT_OPTION`过程,启用需要审计的操作项。

4. 监控审计日志:一旦启用审计选项,数据库将开始记录相应的操作到审计日志文件中。

您可以使用SQL查询或Oracle Enterprise Manager等工具来监控审计日志。

定期检查审计日志以确认是否出现不寻常的活动或潜在的安全威胁。

5. 设置审计日志管理策略:审计日志的文件管理很重要,您可以使用`DBMS_AUDIT_MGMT`包中的过程设置审计日志的管理策略。

可以定义审计日志的保留时间、日志文件的大小限制等。

定期清理旧的审计日志,以确保系统性能和安全。

通过设置Oracle审计日志规则,您可以更好地了解数据库中发生的操作,并及时发现潜在的安全问题。

请确保审计日志的记录和审计管理策略的设置符合您的安全需求,并进行定期的审计日志分析。

oracle审计

oracle审计

审计可以分为3类。

或者说,可以从三种角度去启用审计。

1、语句审计(Statement Audting).对预先指定的某些SQL语句进行审计。

这里从SQL 语句的角度出发,进行指定。

审计只关心执行的语句。

例如,audit CREATE TABLE;命令,就表明对“CREATE TABLE”语句的执行进行记录。

不管这语句是否是针对某个对象的操作2、权限审计(Privilege Auditing)对涉及某些权限的操作进行审计。

这里强调“涉及权限”例如,audit CREATE TABLE;命令,又可以表明对涉及“CREA TE TABLE”权限的操作进行审计。

所以说,在这种命令的情况下,既产生一个语句审计,又产生了一个权限审计。

有时候“语句审计”和“权限审计”的相互重复的。

这一点可以后面证明。

3、对象审计(Object Auditing)。

记录作用在指定对象上的操作。

三、如何启用审计。

通过数据库初始化参数文件中的AUDIT_TRAIL 初始化参数启用和禁用数据库审计。

DB 启用数据库审计并引导所有审计记录到数据库的审计跟踪OS 启用数据库审计并引导所有审计记录到操作系统的审计跟踪。

可以用AUDIT_FILE_DEST 初始化参数来指定审计文件存储的目录。

NONE 禁用审计这个值是默认值四、如何设定所需的审计AUDIT语句。

例如:审计属于用户jward 的dept 表上的所有的SELECT INSERT 和DELETE 语句AUDIT SELECT, INSERT, DELETEON jward.dept;五、控制何时触发审计动作。

1)By session / By Accessby session对每个session中发生的重复操作只记录一次by access对每个session中发生的每次操作都记录,而不管是否重复。

2)Whenever successful/ Whenever not successfulWhenever successful表示操作成功以后才记录下来。

oracle数据库管理员操作日志

oracle数据库管理员操作日志

oracle数据库管理员操作日志
作为Oracle数据库管理员,操作日志是非常重要的工作之一。

数据库管理员需要定期记录数据库的操作日志,以便追踪和监控数据库的活动,保证数据库的安全性和稳定性。

操作日志记录了数据库管理人员和用户对数据库的操作,包括但不限于数据库的创建、修改、删除,用户的访问和权限变更,以及数据库的备份和恢复等操作。

在Oracle数据库中,可以通过以下几种方式记录操作日志:
1. Oracle数据库自带的日志功能,Oracle数据库提供了详细的日志记录功能,可以通过配置参数来开启日志记录,并设置日志的级别和格式。

管理员可以通过查看数据库的日志文件来了解数据库的操作情况。

2. 使用审计功能,Oracle数据库提供了审计功能,可以对数据库的操作进行审计,并记录到审计日志中。

管理员可以通过配置审计策略来监控数据库的操作,包括对特定对象的操作、特定用户的操作等。

3. 使用第三方工具,除了Oracle数据库自带的日志功能外,
还可以使用第三方的监控和日志记录工具来记录数据库的操作日志。

这些工具通常提供了更丰富的功能和更直观的界面,可以帮助管理
员更方便地管理和分析数据库的操作日志。

无论使用哪种方式记录操作日志,数据库管理员都需要定期对
日志进行分析和归档,以便及时发现潜在的问题并采取相应的措施。

此外,数据库管理员还需要遵守相关的法律法规和公司政策,确保
操作日志的安全和完整性,防止日志被篡改或删除。

操作日志对于
数据库的安全和稳定性至关重要,因此数据库管理员需要高度重视
操作日志的记录和管理工作。

Oracle 11g数据库审计功能解析

Oracle 11g数据库审计功能解析

Oracle 11g数据库审计功能解析本文我们主要介绍一个Oracle 11g数据库中审计功能的应用实例,希望能够对您有所帮助。

在用户的profile 属性里面有一个属性:FAILED_LOGIN_ATTEMPTS,该参数默认值是10. 即当我们用户连续10次输入错误密码,这个用户就会被锁住。

用户连词失败次数是在表USER$ 中的lcount字段记录的。

该值默认为0. 当失败一次,该值加1. 成功登录,该值清零。

一般在生产环境下,会根据具体情况设置这个参数,如果防止用户被锁,则将这个参数设置为UNLIMITED. 这个是注意的地方。

当然设置成无限也有它的弊端,比如不能防止暴力破解数据库密码。

有关profile 的更多内容参考:Oracle 用户profile 属性在Oracle 11g中默认启用了对登录注销操作LOGON/LOGOFF的审计,那么如果我们发现用户被锁,那么可以应用11g的审计功能来查看从哪台机器上发来的链接失败导致用户被锁,可以帮助我们定位问题。

脚本如下:1.SQL> selectos_username,userhost,terminal,username,count(*)2. 2 from dba_audit_trail3.3 where returncode = 10174.4 group byos_username,userhost,username,terminal;5. OS_USERNAME USERHOST TERMINAL USERNAME COUNT(*)6.------------------------------------------------------------ ------------------------ ----------7. DavidDai\Administrator WORKGROUP\DAVIDDAI DAVIDDAI ICD 78.DavidDai\Administrator WORKGROUP\DAVIDDAI DAVIDDAI SYSTEM 99. DavidDai\Administrator WORKGROUP\DAVIDDAI DAVIDDAI SYS 310.DavidDai\Administrator WORKGROUP\DAVIDDAI DAVIDDAI EXIT 1注意:对于LOGON PER SECOND很高的数据库,如果应用程序配置文件中的数据库用户密码不正确,同时应用在短期内发起大量会话登录数据库的话可能引发频繁的dc_users字典缓存锁,用户登录无法成功,乃至整个实例hang住。

oracle审计用户

oracle审计用户

oracle审计用户oracle审计主要用于记录用户对数据库所做的操作,基于配置的不同,审计的结果会放在操作系统文件中或者系统表中,默认情况下,使用管理员权限连接实例,开启及关闭数据库是会强制进行审计的,其它的基础的操作则没有进行审计,在一些安全性要求比较高的环境是需要做一些审计的配置的,下文简单介绍一下oracle中审计的配置方法,几种审计方法的不同,以及如何对管理员进行审计.一。

oracle中审计的配置:1.审计相关的三个重要参数:a.audit_file_dest:指定审计文件存放的位置:b.audit_trail:指定审计的类型:none:为系统默认值,不进行审计DB:将审计结果放在数据库表中,aud$,通常只记录连接的信息.DB_EXTENDED:将审计结果放在数据库表中,记录具体执行语句OS:将审计结果记录在操作系统文件中,文件位置由audit_file_dest参数指定,(windows系统中将直接在事件查看器的系统日志中记录)XML:将审计结果记录在audit_file_dest指定位置下的XML文件中。

c.audit_sys_operations:是否对sysdba用户做审计,关于sysdba 用户审计的结果,linux存放在audit_file_dest参数指定位置的aud文件中,windows存放在事件查看器的系统日志中2.审计的级别:开启审计后,可在statement语句、privilege权限和object对象级别对数据库进行审计。

a.statement:按语句来审计如audit table xxx;b.privilege:按权限来审计,如audit lect any tablec.object:按对象来审计,如audit all ployees by HR,只会对hr 用户对employees表执行的操作做审计3.审计的其它相关选项:by access 每个被审计的操作都会生成一条记录by ssion 默认值,每个会话里同类型操作只会生成一条audit trailwhenever successful:操作成功才审计whenever not successful:操作不成功才审计4.查询审计结果的视图沈阳成人英语培训浙江大学2023年录取分数线dba_audit_trail:查看所有的普通审计记录kptdba_fga_audit_trail:查看所有细粒度审计记录sys.aud$审计结果实际存放的系统表5.取消审计: noaudit lect any table6.开启审计方法a.查看参数SQL show parameter auditNAME TYPE VALUE-----------------------------------------------------------------------------audit_file_dest string /u01/oracle/product/admin/orcl/adumpaudit_sys_operations boolean FALSEaudit_syslog_level stringaudit_trail string NONEb.设置审计类型并重启数据库SQL alter system t audit_trail = db_extended scope=spfile;existenceSystem altered.c.审计用户对表操作SQL audit table ;音标mp3Audit succeeded.d.切换用户后创建表SQLconnecttest/********.1.12/orclConnected.SQL create table audtest (id int);Table created.e.管理员登录查看审计结果SQLconnectsys/**********.1.12/orclassysdbaConnected.SQL lect urname,sql_text from dba_audit_trail;USERNAME------------------------------SQL_TEXT--------------------------------------------------------------------------------TESTmy hobbiescreate table audtest (id int)f.审计系统管理员操作SQL alter system t audit_sys_operations= true scope=spfile; vrf System altered.SQLconnectsys/**********.1.12/orclassysdbaConnected.SQL create table systest (id int);Table created.SQLconnectsys/**********.1.12/orclassysdba Connected.SQL create table systest (id int);Table created.SQL create table systest1 (id int);Table created.g.查看系统管理员审计结果Audit file /u01/oracle/product/admin/orcl/adump/ora_5895.aud Oracle Databa 10g Enterpri Edition Relea 10.2.0.1.0 - Production 北京西班牙语培训With the Partitioning, OLAP and Data Mining options ORACLE_HOME = /u01/oracle/product/10.2/db1System name: LinuxNode name: oracle1Relea: 2.6.9-55.ELsmpVersion: #1 SMP Fri Apr 20 17:03:35 EDT 2023 Machine: i686Instance name: orclRedo thread mounted by this instance: 1Oracle process number: 20Unix process pid: 5895, image: oracleorcl@oracle1Mon Mar 28 23:03:28 2023ACTION : 'CONNECT'DATABASE USER: 'sys'PRIVILEGE : SYSDBACLIENT USER: AdministratorCLIENT TERMINAL: PC-20230718IUGMSTATUS: 0Mon Mar 28 23:03:42 2023ACTION : 'create table systest (id int)'DATABASE USER: 'sys'PRIVILEGE : SYSDBACLIENT USER: AdministratorCLIENT TERMINAL: PC-20230718IUGMSTATUS: 0Mon Mar 28 23:08:09 2023ACTION : 'create table systest1 (id int)'swift code是什么方式状语DATABASE USER: 'sys'PRIVILEGE : SYSDBACLIENT USER: AdministratorCLIENT TERMINAL: PC-20230718IUGMSTATUS: 0"ora_5895.aud" 38L, 995C。

oracle审计日志数目

oracle审计日志数目

oracle审计日志数目Oracle审计日志是一种记录数据库操作的重要工具,它可以帮助管理员监控和分析数据库的使用情况。

通过审计日志,管理员可以了解到数据库中发生的各种操作,包括登录、查询、修改、删除等,从而确保数据库的安全性和可靠性。

我们来了解一下Oracle审计日志的基本概念。

审计日志是Oracle数据库中一种特殊的日志文件,它记录了用户对数据库的操作行为。

每当有用户执行一条SQL语句或进行一项数据库操作时,Oracle就会将相关信息写入审计日志中,包括操作的时间、用户名、IP地址、操作类型、操作对象等。

通过分析审计日志,管理员可以了解到数据库的使用情况,及时发现异常操作和潜在的安全风险。

那么,为什么我们需要审计日志呢?首先,审计日志可以帮助管理员监控数据库的使用情况,及时发现并解决潜在的问题。

比如,如果某个用户频繁登录数据库并执行一些敏感操作,管理员可以通过审计日志发现这种异常行为,并采取相应的措施进行处理。

此外,审计日志还可以用于追踪数据库操作的来源,帮助管理员找到数据库中的安全漏洞,并加以修补。

另外,审计日志还可以用于法律调查和取证,对于一些涉及敏感信息的数据库,审计日志可以作为重要的证据材料。

在Oracle数据库中,我们可以通过开启审计功能来生成审计日志。

管理员可以根据需要选择不同的审计级别,比如可以只记录敏感操作或者记录所有的操作。

此外,管理员还可以自定义审计规则,指定需要审计的对象和操作类型。

审计日志可以保存在数据库中,也可以保存在外部文件中,以便于后续的分析和查询。

对于审计日志的分析,通常可以借助一些专门的工具来实现。

比如,我们可以使用Oracle提供的审计工具,如Oracle Audit Vault和Database Firewall,这些工具可以帮助管理员对审计日志进行实时监控和分析。

此外,还有一些第三方的审计工具,如IBM Security Guardium和Imperva SecureSphere等,这些工具具有更加强大的审计和分析功能,可以帮助管理员更好地保护数据库的安全。

Oracle11g数据库审计

Oracle11g数据库审计

Oracle11g数据库审计问题描述:使⽤Oracle 11g的数据库审计问题解决:(1)激活数据库审计(1.1)查看数据库审计是否已经开启如上图所⽰:⾸先使⽤⽤户登陆sqplus,(普通⽤户,或者dba都可以),然后使⽤conn /as sysdba注意:(a)以上使⽤sqlplus可以成功进⾏数据库审计的命令操作,但是在使⽤PL/SQL Developer command line进⾏数据库审计操作时,有些命令⽆法识别例如shutdown immediate (重启数据库)(b)以上使⽤conn / as sysdba 进⾏数据库登陆,使⽤其他⽤户登陆进⾏数据库审计操作时不起作⽤的(1.2)查看数据库审计是否已经开启如上所⽰,使⽤ show parameter audit ;可以查看数据库审计的信息其中audit_sys_operations 的value为false,意味着数据库审计未开启其中audit_trail 的value为DB参数详解:AUDIT_TRAIL启⽤或禁⽤数据库审计。

当设置该参数为NONE或FALSE时,将禁⽌数据库审计;当设置该参数为OS时,将激活数据库审计,并将审计记录写⼊到OS审计跟踪⽂件中;当设置该参数为DB或TRUE时,将激活数据库审计,并将审计记录写⼊到数据字典SYS.AUD$中;当设置该参数为DB_EXTENDED时,不仅将审计记录写⼊到数据字典SYS.AUD$中,还会填充该数据字典的SQLBIND和SQLTEXT列。

(1.3)激活数据库审计如上所⽰修改系统信息,激活数据库审计参数详解:spfile是存储初始化参数的⽂件,还有⼀种是pfile也是存储初始化参数的⽂件,spfile是服务器端维护的,pfile是客户端维护的spfile只能通过系统更改,pfile可以⼿动修改。

(1.4)重启数据库-----应⽤对系统的修改重新查看审计的信息如上显⽰了audit_sys_operations 的值为true,同时audit_trail 的值为db_extended说明数据库审计已经激活注意:以上重新启动数据库使⽤了startup force 命令,同时也可以分别使⽤:shutdown immediate ; 关闭数据库startup;启⽤数据库(2)使⽤审计信息注意:(a) 审计⼀般只⽤于对普通⽤户操作,⼀般不审计SYS⽤户(b) 对于windows系统,对sys⽤户的审计信息并不存在AUDIT_FILE_DEST参数指定的⽬录⾥,⽽是在windows的事件管理器中。

查看oracle数据库审计信息的语句

查看oracle数据库审计信息的语句

查看Oracle数据库审计信息的语句引言Oracle数据库是当前企业级应用最常用的关系型数据库之一,其中的审计功能是保证数据库安全的重要一环。

通过查看数据库审计信息,可以了解数据库的操作记录,追踪异常行为,及时发现安全风险,对数据库进行有效监控和管理。

本文将介绍如何使用语句查看Oracle数据库的审计信息。

了解Oracle数据库审计功能在进行数据库审计之前,首先需要了解Oracle数据库本身提供的审计功能。

Oracle数据库提供了多种审计选项,包括标准审计、细粒度审计和Flashback Data Archive。

标准审计可以记录用户登录和特权操作,细粒度审计可以监控数据库对象的具体访问和修改,Flashback Data Archive可以记录历史数据的变更。

在实际使用中,可以根据具体需求选择合适的审计选项,并配置审计参数。

使用下面的语句查看Oracle数据库审计信息:SELECT os_username, username, userhost, terminal, timestamp, action_name, retu rncode, SQL_TEXTFROM dba_audit_trailWHERE timestamp BETWEEN TO_DATE('2021-01-01 00:00:00', 'YYYY-MM-DD HH24:MI:SS') AND TO_DATE('2021-12-31 23:59:59', 'YYYY-MM-DD HH24:MI:SS')ORDER BY timestamp;该语句使用了dba_audit_trail视图来查询数据库的审计信息。

下面分别解释每个字段的含义:•os_username:操作系统的用户名•username:数据库用户名•userhost:登录用户的主机名•terminal:登录用户的终端•timestamp:操作的时间戳•action_name:操作的类型,如SELECT、INSERT等•returncode:操作的返回代码•SQL_TEXT:执行的SQL语句该语句通过WHERE子句限定了查询的时间范围,并通过ORDER BY子句按照时间顺序排序结果。

oracle审计功能

oracle审计功能
彻底删除策略的方法:
ORCL>exec dbms_fga.drop_policy(object_schema=>'ZBTEST', object_name=> 'zbtestt1', policy_name=> 'check_t_audit');
PL/SQL procedure successfully completed.
Connected.
sys@ORCL)> insert into zbtestt1 values(1);
1 row created.
ORCL> create table zbtestt2(c1 number);
Table created.
sys@ORCL(128.192.128.1)> delete from zbtestt2;
0 rows deleted.
查看是否成功抓取SQL
select username,sql_text from dba_audit_trail;
USERNAME SQL_TEXT
---------- --------------------------------------------------
使策略失效的方法:
ORCL>exec dbms_fga.disable_policy(object_schema=>'ZBTEST', object_name=> 'zbtestt1', policy_name=> 'check_t_audit');
使策略生效的方法:
ORCL>exec dbms_fga.enable_policy(object_schema=>'ZBTEST', object_name=> 'zbtestt1', policy_name=> 'check_t_audit');

oracle审计策略

oracle审计策略

oracle审计策略一、什么是Oracle审计?Oracle审计是指通过记录数据库中的操作以及对数据库对象的访问,来追踪和监控数据库的活动。

审计可以帮助管理员了解用户对数据库的访问情况、检测安全威胁、满足合规性要求等。

二、为什么需要Oracle审计?1. 满足合规性要求许多行业和组织都有强制性的合规性要求,如Sarbanes-Oxley法案、HIPAA等。

这些法规要求企业必须记录和监控其信息系统中的活动,以确保数据安全和隐私保护。

2. 检测安全威胁Oracle审计可以帮助管理员及时发现潜在的安全威胁,如未经授权的访问、恶意软件入侵等。

3. 了解用户行为通过审计记录,管理员可以了解用户对数据库的访问情况,包括哪些用户进行了哪些操作,从而更好地管理和优化数据库。

三、Oracle审计策略1. 审计级别Oracle提供了三种审计级别:标准审计、详细审计和完整审计。

标准审计只记录成功或失败的登录事件;详细审计记录所有DDL语句(如CREATE TABLE)以及所有DML语句(如SELECT、INSERT、UPDATE、DELETE)的执行情况;完整审计不仅记录详细审计中的内容,还会记录所有SELECT语句的执行情况。

2. 审计对象Oracle审计可以针对数据库实例、用户、角色、表空间、表等对象进行设置。

管理员可以根据需要选择需要审计的对象。

3. 审计记录Oracle审计可以将记录保存在操作系统文件中,也可以保存在数据库中。

管理员可以根据需要选择合适的存储方式,并设置审计日志文件大小和保留时间。

4. 审计策略管理员应该制定合适的审计策略,包括审计级别、审计对象、审计记录等方面。

应该考虑到安全性和性能之间的平衡,避免过度或不足的审计。

5. 审核和报告管理员应该定期审核和分析审计记录,并生成相应的报告。

这些报告可以帮助管理员了解数据库活动情况,检测安全威胁,满足合规性要求等。

四、如何开启Oracle审计?1. 开启标准审计在SQL*Plus中使用以下命令:ALTER SYSTEM SET AUDIT_TRAIL=DB SCOPE=SPFILE;SHUTDOWN IMMEDIATE;STARTUP;2. 开启详细或完整审计在SQL*Plus中使用以下命令:AUDIT ALL BY USERNAME BY ACCESS;3. 设置审计对象在SQL*Plus中使用以下命令:AUDIT SELECT TABLE, UPDATE TABLE, DELETE TABLE BY HR;4. 设置审计记录在SQL*Plus中使用以下命令:ALTER SYSTEM SETAUDIT_FILE_DEST='/u01/app/oracle/admin/orcl/adump'; ALTER SYSTEM SET AUDIT_FILE_DEST_SIZE=100M;5. 审核和报告在SQL*Plus中使用以下命令:SELECT * FROM DBA_AUDIT_TRAIL;管理员还可以使用Oracle Audit Vault和Database Firewall等工具来简化审计管理和报告。

oracle 审计日志 设置规则

oracle 审计日志 设置规则

oracle 审计日志设置规则(实用版)目录1.Oracle 审计日志的概念和作用2.Oracle 审计日志的设置规则3.如何开启 Oracle 审计功能4.审计日志的维护和管理5.审计日志的重要性和应用场景正文一、Oracle 审计日志的概念和作用Oracle 审计日志是用于记录数据库中各种操作的一种日志,它可以帮助数据库管理员监控和审查数据库的活动,保证数据的安全和完整性。

通过审计日志,管理员可以了解数据库的运行状况,及时发现并处理潜在的安全隐患和问题。

二、Oracle 审计日志的设置规则设置 Oracle 审计日志需要遵循以下规则:1.配置审计跟踪:通过使用 ALTER SYSTEM 命令设置auditsysoperation 属性为 TRUE,开启审计跟踪功能。

2.配置审计日志:使用 ALTER SYSTEM 命令设置 audittraildb 属性为 extended,开启审计日志功能。

3.配置审计日志文件:使用 ALTER SYSTEM 命令设置audit_trail_file_name 属性,指定审计日志文件的名称和路径。

4.重启数据库:执行 SHUTDOWN IMMEDIATE 命令,重启数据库,使审计设置生效。

三、如何开启 Oracle 审计功能1.使用本地连接方式,以 sysdba 或 sysoper 角色登录 Oracle 数据库。

2.执行以下 SQL 命令,开启审计跟踪功能:```ALTER SYSTEM SET auditsysoperation = TRUE;```3.执行以下 SQL 命令,开启审计日志功能:```ALTER SYSTEM SET audittraildb = extended;```4.执行以下 SQL 命令,设置审计日志文件的名称和路径:```ALTER SYSTEM SET audit_trail_file_name = "审计日志文件名.log";```5.执行 SHUTDOWN IMMEDIATE 命令,重启数据库,使审计设置生效。

oracle 审计

oracle 审计

·使用SQL语句来挑选审计选择项;
·审计对该用户所拥有的表或视图的成功或不成功的存取企图;
·有选择的审计各种类型的SQL操作(SELECT、UPDATE、INSERT、DELETE);
·控制审计的程度(是以SESSION还是ACCESS为单位)。
另外,对于DBA用户还可以以下审计功能:
startup force
2, 启/禁用审计
audit table by scott
noaudit table by scott
3, 查询审计
先从字典中找出audit的相关视图
dba_stmt_audit_opts 关于已定义的审计
要支持审计必须先创建审计视图,查询语句如下:
select view_name from user_views where view_name='ALL_DEF_AUDIT_OPTS';
如果没有就用以下语句创建
@D:\oracle\ora92\rdbms\admin\cataudit.sql
select username,timestamp,owner,action_name,obj_name from dba_audit_object;
6、设置sql跟踪
show parameter sql_trace;
(1)timed_statistics=true
默认值
(2)user_dump_dest=目录名
同时也可用一下语句删除
@D:\oracle\ora92\rdbms\admin\catnoaud.sql
2、语句级审计
audit sql语句 [by 用户名] [by session或者access] [whenever [not] successful];

oracle审计日记

oracle审计日记

oracle审计日记Oracle审计日记今天我将记录一下我在Oracle审计过程中的一些观察和体会。

Oracle审计是数据库管理中非常重要的一环,通过审计日志可以追踪数据库的操作行为,保证数据的安全和合规性。

我需要说明一下审计日志的作用和重要性。

审计日志可以记录数据库中的各种操作行为,如登录、查询、插入、更新、删除等,通过对这些操作的审计,可以及时发现潜在的安全威胁和违规行为。

同时,审计日志也是数据库管理人员进行故障排查和性能优化的重要依据,可以帮助我们快速定位问题并做出相应的处理和优化。

在进行Oracle审计时,我们首先需要配置审计策略。

通过设置审计策略,可以指定需要审计的操作类型、对象和用户等信息。

例如,我们可以设置只审计管理员用户的操作,或者只审计对敏感数据表的操作。

审计策略的设置需要根据具体的业务需求和安全要求进行调整,以达到最佳的审计效果。

接下来,我将介绍一些常用的审计日志信息。

首先是登录审计。

通过登录审计,我们可以了解到谁在什么时间登录了数据库,通过哪种方式登录的,以及登录是否成功等。

这些信息对于监控数据库的安全性非常重要。

其次是执行语句审计。

通过执行语句审计,我们可以了解到具体的SQL语句是如何执行的,包括执行时间、执行计划、影响的行数等信息。

这些信息对于优化SQL语句和排查性能问题非常有帮助。

另外,还有对象审计和敏感数据审计等,可以根据具体的需求进行配置和使用。

在实际的审计过程中,我们还需要注意一些问题。

首先是审计日志的保留和管理。

由于审计日志的产生量较大,我们需要定期清理和归档审计日志,以防止日志文件过大导致系统性能下降。

其次是审计日志的分析和报告。

审计日志的分析可以帮助我们发现异常行为和安全漏洞,及时采取措施进行处理。

而审计日志的报告可以向上级领导和安全团队汇报数据库的安全状况和审计结果,以便制定相应的安全策略和措施。

我想强调一下审计日志的重要性和必要性。

通过对数据库操作的审计,可以及时发现和防止潜在的安全威胁和违规行为,保障数据库的安全和合规性。

Oracle审计(Audit)监视用户所执行的数据库操作实例

Oracle审计(Audit)监视用户所执行的数据库操作实例

Oracle审计(Audit)监视用户所执行的数据库操作:A、审计相关的表安装:SQL> conn sys/???? as sysdba;SQL> select * from sys.aud$;SQL> select * from dba_audit_trail;如果做上述查询的时候发现表不存在,说明审计相关的表还没有安装,需要安装。

SQL> @$ORACLE_HOME/rdbms/admin/cataudit.sql审计表安装在SYSTEM 表空间, 所以要确保SYSTEM 表空间又足够的空间存放审计信息。

B、激活审计:SQL> show parameter audit;NAME TYPE VALUE------------------------------------ ----------- ------------------------------audit_file_dest string D:\APP\ADMIN\ADMIN\ORCL\ADUMPaudit_sys_operations boolean FALSEaudit_trail string DBSQL> alter system set audit_sys_operations=TRUE scope=spfile;System alteredSQL> alter system set audit_trail=db_extended scope=spfile;System altered------------------------------------------*****----------------------------------------Audit_trail参数值:None: 是默认值,不做审计;DB:将audit trail记录在数据库的审计相关表中,审计的结果只有连接信息;DB_Extended:这样审计结果里面除了连接信息还包含了当时执行的具体语句;OS:将audit trail记录在操作系统文件中,文件名由audit_file_dest 参数指定;XML:10g 里新增的。

oracle19c 查询审计内容(一)

oracle19c 查询审计内容(一)

oracle19c 查询审计内容(一)Oracle19c查询审计内容什么是Oracle数据库审计数据库审计是指记录和监控对数据库中敏感数据的访问和修改的过程。

Oracle数据库提供了一套全面的审计功能,可以帮助管理员追踪数据库中的操作并确保数据的安全性。

为什么需要Oracle数据库审计•合规需求:许多行业有特定的合规要求,数据库审计可以帮助满足这些要求,如PCI DSS、HIPAA等。

•安全性:审计可以帮助发现潜在的安全威胁和漏洞,并及时采取措施进行修补。

•跟踪操作:审计功能可以帮助管理员跟踪敏感数据的访问、修改和删除,以及检查不当的操作行为。

如何开启Oracle数据库审计1.创建审计策略:首先,管理员需要创建一个审计策略,该策略将确定要审计的操作和对象。

2.启用审计:在创建审计策略后,管理员需要启用审计功能。

3.监视审计日志:开启审计后,所有审计事件将被记录在特定的审计日志中,管理员可以定期监视这些日志以检查数据库操作。

查询审计内容为了查看已审计的内容,可以使用各种SQL语句查询审计日志表。

以下是一些常用的查询语句:1.查询所有审计日志记录:SELECT * FROM dba_audit_trail;2.按用户查询审计日志记录:SELECT * FROM dba_audit_trail WHERE username = 'USE RNAME';3.按时间范围查询审计日志记录:SELECT * FROM dba_audit_trail WHERE timestamp >= TO_DATE('', 'YYYY-MM-DD')AND timestamp <= TO_DATE('', 'YYYY-MM-DD');4.按操作类型查询审计日志记录:SELECT * FROM dba_audit_trail WHERE action_name = ' SELECT';5.按对象类型查询审计日志记录:SELECT * FROM dba_audit_trail WHERE object_type = ' TABLE';6.按IP地址查询审计日志记录:SELECT * FROM dba_audit_trail WHERE client_id = 'IP _ADDRESS';结论Oracle19c提供了强大的数据库审计功能,帮助管理员跟踪和监控对敏感数据的访问和修改。

oracle19c 查询审计内容

oracle19c 查询审计内容

oracle19c 查询审计内容
【原创实用版】
目录
1.Oracle19c 简介
2.Oracle19c 的审计功能
3.查询审计内容的方法
4.结论
正文
一、Oracle19c 简介
Oracle19c 是甲骨文公司(Oracle)发布的一款关系型数据库管理系统。

它是 Oracle 数据库系列的最新版本,具有许多创新功能和性能改进。

Oracle19c 提供了高度可扩展、高性能和安全的数据库解决方案,适用于各种规模企业和组织的不同业务需求。

二、Oracle19c 的审计功能
Oracle19c 的审计功能可以帮助企业和组织更好地监控和分析数据
库活动,从而提高数据库安全性和数据完整性。

Oracle19c 审计功能包括:
1.数据库审计:可以对数据库中的数据进行审计,检查数据的更改、删除和插入操作。

2.语句审计:可以对数据库中的 SQL 语句进行审计,检查语句的执行情况和结果。

3.异常审计:可以对数据库中的异常情况进行审计,检查异常的原因和影响。

4.性能审计:可以对数据库的性能进行审计,检查性能瓶颈和问题。

三、查询审计内容的方法
在 Oracle19c 中,可以使用 AUDIT 命令来查询审计内容。

以下是一个简单的示例:
```
SELECT * FROM dba_audit_trails;
```
这个命令将返回所有审计轨迹的信息,包括审计用户、审计时间、审计操作和审计结果等。

可以根据需要添加其他条件来筛选审计内容。

四、结论
Oracle19c 的审计功能可以帮助企业和组织更好地保护数据库的安全和完整性。

oracle审计规则100条

oracle审计规则100条

oracle审计规则100条Oracle是一种常用的关系型数据库管理系统,被广泛应用于企业的数据存储和管理中。

为了确保数据库的安全性和合规性,Oracle审计规则起到了重要的作用。

下面将介绍100条Oracle审计规则,以帮助企业更好地管理和保护其数据库。

1. 启用审计功能,记录所有数据库活动。

2. 定期审查审计日志,发现异常活动。

3. 限制对审计日志的访问权限,只允许授权人员查看。

4. 对数据库管理员进行背景调查,确保其信任和可靠性。

5. 确保数据库管理员不滥用其权限。

6. 对数据库管理员的操作进行审计。

7. 确保数据库管理员的密码强度,定期更换密码。

8. 禁止共享数据库管理员账号和密码。

9. 禁止使用默认的数据库管理员账号和密码。

10. 禁止使用弱密码,如123456、password等。

11. 禁止使用与用户名相同的密码。

12. 禁止使用容易被猜测的密码,如生日、电话号码等。

13. 禁止使用过去使用过的密码。

14. 禁止将密码存储在明文形式。

15. 启用密码复杂性检查,要求密码包含大小写字母、数字和特殊字符。

16. 设置密码过期策略,定期要求用户更换密码。

17. 禁止共享数据库账号和密码。

18. 禁止使用默认的数据库账号和密码。

19. 禁止使用弱密码,如123456、password等。

20. 禁止使用与用户名相同的密码。

21. 禁止使用容易被猜测的密码,如生日、电话号码等。

22. 禁止使用过去使用过的密码。

23. 禁止将密码存储在明文形式。

24. 启用密码复杂性检查,要求密码包含大小写字母、数字和特殊字符。

25. 设置密码过期策略,定期要求用户更换密码。

26. 禁止使用未经授权的数据库连接工具。

27. 禁止使用未经授权的数据库客户端。

28. 禁止使用未经授权的数据库驱动程序。

29. 禁止使用未经授权的数据库插件。

31. 禁止使用未经授权的数据库脚本。

32. 禁止使用未经授权的数据库存储过程。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1、什么是审计审计(Audit)用于监视用户所执行的数据库操作,并且Oracle会将审计跟踪结果存放到OS文件(默认位置为$ORACLE_BASE/admin/$ORACLE_SID/adump/)或数据库(存储在system表空间中的SYS.AUD$表中,可通过视图dba_audit_trail查看)中。

默认情况下审计是没有开启的。

不管你是否打开数据库的审计功能,以下这些操作系统会强制记录:用管理员权限连接Instance;启动数据库;关闭数据库。

2、和审计相关的两个主要参数Audit_sys_operations:默认为false,当设置为true时,所有sys用户(包括以sysdba,sysoper身份登录的用户)的操作都会被记录,audit trail不会写在aud$表中,这个很好理解,如果数据库还未启动aud$不可用,那么像conn /as sysdba这样的连接信息,只能记录在其它地方。

如果是windows平台,audti trail会记录在windows的事件管理中,如果是linux/unix平台则会记录在audit_file_dest参数指定的文件中。

Audit_trail:None:是默认值,不做审计;DB:将audit trail 记录在数据库的审计相关表中,如aud$,审计的结果只有连接信息;DB_Extended:这样审计结果里面除了连接信息还包含了当时执行的具体语句;OS:将audit trail 记录在操作系统文件中,文件名由audit_file_dest参数指定;XML:10g里新增的。

注:这两个参数是static参数,需要重新启动数据库才能生效。

3、审计级别当开启审计功能后,可在三个级别对数据库进行审计:Statement(语句)、Privilege(权限)、object(对象)。

Statement:按语句来审计,比如audit table 会审计数据库中所有的create table,drop table,truncate table语句,alter session by cmy会审计cmy用户所有的数据库连接。

Privilege:按权限来审计,当用户使用了该权限则被审计,如执行grant select any table to a,当执行了audit select any table语句后,当用户a 访问了用户b的表时(如select * from b.t)会用到select any table权限,故会被审计。

注意用户是自己表的所有者,所以用户访问自己的表不会被审计。

Object:按对象审计,只审计on关键字指定对象的相关操作,如aduit alter,delete,drop,insert on cmy.t by scott; 这里会对cmy用户的t表进行审计,但同时使用了by子句,所以只会对scott用户发起的操作进行审计。

注意Oracle没有提供对schema中所有对象的审计功能,只能一个一个对象审计,对于后面创建的对象,Oracle则提供on default子句来实现自动审计,比如执行audit drop on default by access;后,对于随后创建的对象的drop操作都会审计。

但这个default会对之后创建的所有数据库对象有效,似乎没办法指定只对某个用户创建的对象有效,想比trigger可以对schema的DDL进行“审计”,这个功能稍显不足。

4、审计的一些其他选项by access / by session:by access 每一个被审计的操作都会生成一条audit trail。

by session 一个会话里面同类型的操作只会生成一条audit trail,默认为by session。

whenever [not] successful:whenever successful 操作成功(dba_audit_trail中returncode字段为0) 才审计,whenever not successful 反之。

省略该子句的话,不管操作成功与否都会审计。

5、和审计相关的视图dba_audit_trail:保存所有的audit trail,实际上它只是一个基于aud$的视图。

其它的视图dba_audit_session,dba_audit_object,dba_audit_statement都只是dba_audit_trail的一个子集。

dba_stmt_audit_opts:可以用来查看statement审计级别的audit options,即数据库设置过哪些statement 级别的审计。

dba_obj_audit_opts,dba_priv_audit_opts视图功能与之类似all_def_audit_opts:用来查看数据库用on default子句设置了哪些默认对象审计。

6、取消审计将对应审计语句的audit改为noaudit即可,如audit session whenever successful对应的取消审计语句为noaudit session whenever successful;8、实例讲解8.1、激活审计sqlplus / as sysdbaSQL> show parameter auditNAME TYPE VALUE------------------------------------ ----------- ------------------------------audit_file_dest string /u01/app/oracle/admin/ORCL/adumpaudit_sys_operations boolean FALSEaudit_syslog_level stringaudit_trail string NONESQL> alter system set audit_sys_operations=TRUE scope=spfile; --审计管理用户(以sysdba/sysoper 角色登陆)SQL> alter system set audit_trail=db_extended scope=spfile;SQL> startup force;SQL> show parameter auditNAME TYPE VALUE------------------------------------ ----------- ------------------------------audit_file_dest string /u01/app/oracle/admin/ORCL/adumpaudit_sys_operations boolean TRUEaudit_syslog_level stringaudit_trail string DB_EXTENDED8.2、开始审计sqlplus / as sysdba--记录对一个表的所有操作SQL> audit all on t_test;SQL> conn u_testSQL> select * from t_test;SQL> insert into u_test.t_test (c2,c5) values ('test1','2');SQL> commit;SQL> delete from u_test.t_test;SQL> commit;SQL> conn /as sysdbaSQL> selectOS_USERNAME,username,USERHOST,TERMINAL,TIMESTAMP,OWNER,obj_name,ACTION_NAME ,sessionid,os_process,sql_bind,sql_text from dba_audit_trail;sql> audit select table by u_test by access;如果在命令后面添加by user则只对user的操作进行审计,如果省去by用户,则对系统中所有的用户进行审计(不包含sys用户).例:AUDIT DELETE ANY TABLE; --审计删除表的操作AUDIT DELETE ANY TABLE WHENEVER NOT SUCCESSFUL; --只审计删除失败的情况AUDIT DELETE ANY TABLE WHENEVER SUCCESSFUL; --只审计删除成功的情况AUDIT DELETE,UPDATE,INSERT ON user.table by test; --审计test用户对表user.table的delete,update,insert操作8.3、撤销审计SQL> noaudit all on t_test;9、审计语句多层环境下的审计:appserve-应用服务器,jackson-clientAUDIT SELECT TABLE BY appserve ON BEHALF OF jackson;审计连接或断开连接:AUDIT SESSION;AUDIT SESSION BY jeff, lori; -- 指定用户审计权限(使用该权限才能执行的操作):AUDIT DELETE ANY TABLE BY ACCESS WHENEVER NOT SUCCESSFUL;AUDIT DELETE ANY TABLE;AUDIT SELECT TABLE, INSERT TABLE, DELETE TABLE, EXECUTE PROCEDURE BY ACCESS WHENEVER NOT SUCCESSFUL;对象审计:AUDIT DELETE ON jeff.emp;AUDIT SELECT, INSERT, DELETE ON jward.dept BY ACCESS WHENEVER SUCCESSFUL;取消审计:NOAUDIT session;NOAUDIT session BY jeff, lori;NOAUDIT DELETE ANY TABLE;NOAUDIT SELECT TABLE, INSERT TABLE, DELETE TABLE,EXECUTE PROCEDURE; NOAUDIT ALL; -- 取消所有statement审计NOAUDIT ALL PRIVILEGES; -- 取消所有权限审计NOAUDIT ALL ON DEFAULT; -- 取消所有对象审计10、清除审计信息DELETE FROM SYS.AUD$;DELETE FROM SYS.AUD$ WHERE obj$name='EMP';11、审计视图STMT_AUDIT_OPTION_MAP -- 审计选项类型代码AUDIT_ACTIONS -- action代码ALL_DEF_AUDIT_OPTS -- 对象创建时默认的对象审计选项DBA_STMT_AUDIT_OPTS -- 当前数据库系统审计选项DBA_PRIV_AUDIT_OPTS -- 权限审计选项DBA_OBJ_AUDIT_OPTSUSER_OBJ_AUDIT_OPTS; -- 对象审计选项DBA_AUDIT_TRAILUSER_AUDIT_TRAIL -- 审计记录DBA_AUDIT_OBJECTUSER_AUDIT_OBJECT -- 审计对象列表DBA_AUDIT_SESSIONUSER_AUDIT_SESSION -- session审计DBA_AUDIT_STATEMENTUSER_AUDIT_STATEMENT -- 语句审计DBA_AUDIT_EXISTS -- 使用BY AUDIT NOT EXISTS选项的审计DBA_AUDIT_POLICIES -- 审计POLICIESDBA_COMMON_AUDIT_TRAIL -- 标准审计+精细审计12、将审计结果表从system表空间里移动到别的表空间上实际上sys.aud$表上包含了两个lob字段,并不是简单的move table就可以。

相关文档
最新文档