28 Administering the Audit Trail
Users who have been granted the AUDIT_ADMIN
role can manage the audit trail, archive the audit trail, and purge audit trail records.
- Managing the Unified Audit Trail
Auditing is enabled by default, but you can control when audit records are written to disk. - Archiving the Audit Trail
You can archive the traditional operating system, unified database, and traditional database audit trails. - Purging Audit Trail Records
TheDBMS_AUDIT_MGMT
PL/SQL package can schedule automatic purge jobs, manually purge audit records, and perform other audit trail operations. - Audit Trail Management Data Dictionary Views
Oracle Database provides data dictionary views that list information about audit trail management settings.
Parent topic: Monitoring Database Activity with Auditing
28.1 Managing the Unified Audit Trail
Auditing is enabled by default, but you can control when audit records are written to disk.
- When and Where Are Audit Records Created?
Auditing is always enabled. Oracle Database generates audit records during or after the execution phase of the audited SQL statements. - Activities That Are Mandatorily Audited
Certain security sensitive database activities are always audited and such audit configuration cannot be disabled. - How Do Cursors Affect Auditing?
For each execution of an auditable operation within a cursor, Oracle Database inserts one audit record into the audit trail. - Writing the Unified Audit Trail Records to the AUDSYS Schema
Oracle Database automatically writes audit records to an internal relational table in theAUDSYS
schema. - Writing the Unified Audit Trail Records to SYSLOG or the Windows Event Viewer
You can write the unified audit trail records to SYSLOG or the Windows Event Viewer by setting an initialization parameter. - When Audit Records Are Written to the Operating System
In situations where the database table is unable to accept unified audit records, these records will be written to operating system spillover audit files (.bin
format). - Moving Operating System Audit Records into the Unified Audit Trail
Audit records that have been written to the spillover audit files can be moved to the unified audit trail database table. - Exporting and Importing the Unified Audit Trail Using Oracle Data Pump
You can include the unified audit trail in Oracle Database Pump export and import dump files. - Disabling Unified Auditing
You can disable unified auditing.
Related Topics
Parent topic: Administering the Audit Trail
28.1.1 When and Where Are Audit Records Created?
Auditing is always enabled. Oracle Database generates audit records during or after the execution phase of the audited SQL statements.
Oracle Database individually audits SQL statements inside PL/SQL program units, as necessary, when the program unit is run.
To improve read performance of the unified audit trail, the unified audit records are written immediately to disk to an internal relational table in the AUDSYS
schema. In the previous release, the unified audit records were written to SecureFile LOBs. If you had migrated to unified auditing in Oracle Database 12c release 1 (12.1), then you can manually transfer the unified audit records from the SecureFile LOBS to this internal table. If the version of the database that you are using supports partitioned tables, then this internal table is a partitioned table. In this case, you can modify the partition interval of the table by using the DBMS_AUDIT_MGMT.ALTER_PARTITION_INTERVAL
procedure. The partitioned version of this table is based on the EVENT_TIMESTAMP
timestamp as a partition key with a default partition interval of one month. If the database version does not support partitioning, then the internal table is a regular, non-partitioned table.
The generation and insertion of an audit trail record is independent of the user transaction being committed. That is, even if a user transaction is rolled back, the audit trail record remains committed.
Statement and privilege audit options from unified audit policies that are in effect at the time a database user connects to the database remain in effect for the duration of the session. When the session is already active, setting or changing statement or privilege unified audit options does not take effect in that session. The modified statement or privilege audit options take effect only when the current session ends and a new session is created.
In contrast, changes to schema object audit options become immediately effective for current sessions.
By default, audit trail records are written to the AUDSYS
schema in the SYSAUX
tablespace. You can designate a different tablespace, including one that is encrypted, by using the DBMS_AUDIT_MGMT.SET_AUDIT_TRAIL_LOCATION
procedure.
28.1.2 Activities That Are Mandatorily Audited
Certain security sensitive database activities are always audited and such audit configuration cannot be disabled.
The UNIFIED_AUDIT_TRAIL
data dictionary view captures activities from administrative users such as SYSDBA
, SYSBACKUP
, and SYSKM
. You do not need to audit the unified audit trail. The unified audit trail resides in a read-only table in the AUDSYS
schema. Hence, DMLs are not permitted on the unified audit trail views. Even DML and DDL operations on the underlying dictionary tables from AUDSYS
schema are not permitted.
The SYSTEM_PRIVILEGE_USED
column shows the type of administrative privilege that was used for the activity.
Mandatorily Audited Non-Audit-Related Activities
-
ORADEBUG
utility
Mandatorily Audited Audit-Related Activities
-
CREATE AUDIT POLICY
-
ALTER AUDIT POLICY
-
DROP AUDIT POLICY
-
AUDIT
-
NOAUDIT
-
EXECUTE
of theDBMS_FGA
PL/SQL package -
EXECUTE
of theDBMS_AUDIT_MGMT
PL/SQL package -
ALTER TABLE
attempts on theAUDSYS
audit trail table (remember that this table cannot be altered) -
Top level statements by the administrative users
SYS
,SYSDBA
,SYSOPER
,SYSASM
,SYSBACKUP
,SYSDG
, andSYSKM
, until the database opens. When the database opens, Oracle Database audits these users using the audit configurations in the system—not just the ones that were applied using theBY
clause in theAUDIT
statement, for example, but those that were applied for all users whenAUDIT
statement does not have aBY
clause or when theEXCEPT
clause was used and these users were not excluded. -
All user-issued DML statements on the
SYS.AUD$
andSYS.FGA_LOG$
dictionary tables -
Any attempts to modify the data or metadata of the unified audit internal table.
SELECT
statements on this table are not audited by default or mandatorily. -
All configuration changes that are made to Oracle Database Vault
Mandatorily Audited Access to Sensitive Columns in the Oracle Optimizer Dictionary Tables
Be aware that internal access to these table columns by the DBMS_STATS
package does not generate mandatory audit records. The optimizer dictionary tables are as follows:
Optimizer Dictionary Table | Columns |
---|---|
SYS.HIST_HEAD$ |
minimum , maximum , lowval , hival |
SYS.HISTGRM$ |
endpoint , epvalue_raw |
SYS.WRI$_OPTSTAT_HISTHEAD_HISTORY |
minimum , maximum , lowval , hival |
SYS.WRI$_OPSTAT_HISTGRM_HISTORY |
endpoint , epvalue_raw |
Related Topics
Parent topic: Managing the Unified Audit Trail
28.1.3 How Do Cursors Affect Auditing?
For each execution of an auditable operation within a cursor, Oracle Database inserts one audit record into the audit trail.
Events that cause cursors to be reused include the following:
-
An application, such as Oracle Forms, holding a cursor open for reuse
-
Subsequent execution of a cursor using new bind variables
-
Statements executed within PL/SQL loops where the PL/SQL engine optimizes the statements to reuse a single cursor
Auditing is not affected by whether or not a cursor is shared. Each user creates her or his own audit trail records on first execution of the cursor.
Parent topic: Managing the Unified Audit Trail
28.1.4 Writing the Unified Audit Trail Records to the AUDSYS Schema
Oracle Database automatically writes audit records to an internal relational table in the AUDSYS
schema.
In Oracle Database 12c release 1 (12.1), you had the option of queuing the audit records in memory (queued-write mode) and be written periodically to the AUDSYS
schema audit table. However, starting with Oracle Database 12c release 2 (12.2), immediate-write mode and queued-write mode are deprecated. The parameters that controlled them (UNIFIED_AUDIT_SGA_QUEUE_SIZE
, DBMS_AUDIT_MGMT.AUDIT_TRAIL_IMMEDIATE_WRITE
, and DBMS_AUDIT_MGMT.AUDIT_TRAIL_QUEUED_WRITE
), while still viewable, no longer have any functionality.
The new functionality of having audit records always written to a relational table in the AUDSYS
schema prevents the risk of audit records being lost in the event of an instance crash or during a SHUTDOWN ABORT
operation. The new functionality also improves the performance of the audit trail and the database as a whole.
If you have upgraded from Oracle Database 12c release 1 (12.1) and migrated to unified auditing in that release, then Oracle recommends that you use the DBMS_AUDIT_MGMT.TRANSFER_UNIFIED_AUDIT_RECORDS
procedure to transfer the audit records as generated in the previous release to the AUDSYS
audit internal table. Oracle Database Upgrade Guide provides information about transferring unified audit records after an upgrade.
Related Topics
Parent topic: Managing the Unified Audit Trail
28.1.5 Writing the Unified Audit Trail Records to SYSLOG or the Windows Event Viewer
You can write the unified audit trail records to SYSLOG or the Windows Event Viewer by setting an initialization parameter.
- About Writing the Unified Audit Trail Records to SYSLOG or the Windows Event Viewer
With this feature, you can copy some of the key unified audit fields to SYSLOG or the Windows Event Viewer. - Enabling SYSLOG and Windows Event Viewer Captures for the Unified Audit Trail
You can write a subset of unified audit trail records to the UNIX SYSLOG or to the Windows Event Viewer.
Parent topic: Managing the Unified Audit Trail
28.1.5.1 About Writing the Unified Audit Trail Records to SYSLOG or the Windows Event Viewer
With this feature, you can copy some of the key unified audit fields to SYSLOG or the Windows Event Viewer.
Unlike traditional audit, only key fields of unified audit records in the UNIFIED_AUDIT_TRAIL
data dictionary view are copied to SYSLOG. SYSLOG records in a unified audit environment provide proof of operational integrity.
You can configure this feature on both UNIX and Microsoft Windows systems. On Windows systems, you either enable it or disable it. If enabled, it writes the records to the Windows Event Viewer.
On UNIX systems, you can fine-tune the capture of unified audit trail records for SYSLOG to specify the facility where the SYSLOG records are sent and the severity level of the records (for example, DEBUG
if it is capturing debugging-related messages).
Table 28-1 maps the names given to the unified audit records fields that are written to SYSLOG and the Windows Event Viewer to the corresponding column names in the UNIFIED_AUDIT_TRAIL
view.
Table 28-1 Audit Record Field Names for SYSLOG and the Windows Event Viewer
Field Name | Column Name in UNIFIED_AUDIT_TRAIL | Column Type | Column Description |
---|---|---|---|
|
|
|
Type of the audit record |
|
|
|
Database identifier |
|
|
|
Session identifier |
|
|
|
Client identifier in the session |
|
|
|
Identifier for each statement run in the system |
|
|
|
Session user |
|
|
|
Effective user for the audited event |
|
|
|
Action code of the audited event |
|
|
|
Return code for the audited event |
|
|
|
Schema name of the object |
|
|
|
Name of the object |
|
|
|
GUID of the container in which the unified audit record is generated |
28.1.6 When Audit Records Are Written to the Operating System
In situations where the database table is unable to accept unified audit records, these records will be written to operating system spillover audit files (.bin
format).
The default locations for unified audit spillover .bin
files are as follows:
- For pluggable databases (PDBs):
$ORACLE_BASE/audit/$ORACLE_SID/PDB_GUID
- For non-consolidated databases, or for the CDB root:
$ORACLE_BASE/audit/$ORACLE_SID/
The ability to write to the database table can fail in situations such as the following: the audit tablespace is offline, the tablespace is read-only, the tablespace is full, the database is read-only, and so on. The unified audit records will continue to be written to OS spillover files until the OS disk space becomes full. At this point, when there is no room in the OS for the audit records, user auditable transactions will fail with ORA-02002 error while writing to audit trail
errors. To prevent this problem, Oracle recommends that you purge the audit trail on a regular basis.
Related Topics
Parent topic: Managing the Unified Audit Trail
28.1.7 Moving Operating System Audit Records into the Unified Audit Trail
Audit records that have been written to the spillover audit files can be moved to the unified audit trail database table.
When the database is not writable (such as during database mounts), if the database is closed, or if it is read-only, then Oracle Database writes the audit records to these external files. The default location for these external files is the $ORACLE_BASE/audit/$ORACLE_SID
directory.
You can load the files into the database by running the DBMS_AUDIT_MGMT.LOAD_UNIFIED_AUDIT_FILES
procedure. Be aware that if you are moving a large number of operating system audit records in the external files, performance may be affected.
To move the audit records in these files to the AUDSYS
schema audit table when the database is writable:
The audit records are loaded into the AUDSYS
schema audit table immediately, and then deleted from the $ORACLE_BASE/audit/$ORACLE_SID
directory.
Parent topic: Managing the Unified Audit Trail
28.1.8 Exporting and Importing the Unified Audit Trail Using Oracle Data Pump
You can include the unified audit trail in Oracle Database Pump export and import dump files.
The unified audit trail is automatically included in either full database or partial database export and import operations using Oracle Data Pump. As part of the schema level export or import operation, Oracle Database does not include the audit policy's metadata in the SYS
schema during the export or import operation. Instead, use full export (expdp
) or import (impdp
) for the export and import of the metadata in unified audit policies.
For example, for a partial database export operation that does not use schema level export or import, if you wanted to export only the unified audit trail tables, then you could enter the following commands:
- In SQL*Plus, move any operating system audit records that have been written to the spillover audit files to the unified audit trail table. Doing so ensures that all records will be exported.
- From the operating system prompt, run the following command:
expdp system full=y directory=aud_dp_dir logfile=audexp_log.log dumpfile=audexp_dump.dmp version=18.02.00.02.00 INCLUDE=AUDIT_TRAILS Password: password
Next, you can import all the exported content by reading the export dump file. This operation imports only the unified audit trail tables.
impdp system
full=y
directory=aud_dp_dir
dumpfile=audexp_dump.dmp
logfile=audimp_log.log
Password: password
You do not need to perform any special configuration to achieve this operation. However, you must have the EXP_FULL_DATABASE
role if you are performing the export operation and the IMP_FULL_DATABASE
role if you are performing the import operation.
Parent topic: Managing the Unified Audit Trail
28.1.9 Disabling Unified Auditing
You can disable unified auditing.
Related Topics
Parent topic: Managing the Unified Audit Trail
28.2 Archiving the Audit Trail
You can archive the traditional operating system, unified database, and traditional database audit trails.
- Archiving the Traditional Operating System Audit Trail
You can create an archive of the traditional operating system audit files after you have upgraded Oracle Database. - Archiving the Unified and Traditional Database Audit Trails
You should periodically archive and then purge the audit trail to prevent it from growing too large.
Parent topic: Administering the Audit Trail
28.2.1 Archiving the Traditional Operating System Audit Trail
You can create an archive of the traditional operating system audit files after you have upgraded Oracle Database.
To archive the traditional operating system audit trail from an upgraded database, use your platform-specific operating system tools to create an archive of the traditional operating system audit files.
-
Use the following methods to archive the traditional operating system audit files:
-
Use Oracle Audit Vault and Database Firewall. You install Oracle Audit Vault and Database Firewall separately from Oracle Database.
-
Create tape or disk backups. You can create a compressed file of the audit files, and then store it on tapes or disks. Consult your operating system documentation for more information.
-
Afterwards, you should purge (delete) the traditional operating system audit records to facilitate audit trail management.
Related Topics
Parent topic: Archiving the Audit Trail
28.2.2 Archiving the Unified and Traditional Database Audit Trails
You should periodically archive and then purge the audit trail to prevent it from growing too large.
Archiving and purging facilitate the purging of the database audit trail.
You can create an archive of the unified and traditional database audit trail by using Oracle Audit Vault and Database Firewall. You install Oracle Audit Vault and Database Firewall separately from Oracle Database.
After you complete the archive, you can purge the database audit trail contents.
-
To archive the unified, traditional standard, and traditional fine-grained audit records, copy the relevant records to a normal database table.
For example:
INSERT INTO table SELECT ... FROM UNIFIED_AUDIT_TRAIL ...; INSERT INTO table SELECT ... FROM SYS.AUD$ ...; INSERT INTO table SELECT ... FROM SYS.FGA_LOG$ ...;
Related Topics
Parent topic: Archiving the Audit Trail
28.3 Purging Audit Trail Records
The DBMS_AUDIT_MGMT
PL/SQL package can schedule automatic purge jobs, manually purge audit records, and perform other audit trail operations.
- About Purging Audit Trail Records
You can use a variety of ways to purge audit trail records. - Selecting an Audit Trail Purge Method
You can perform the purge on a regularly scheduled basis or at a specified times. - Scheduling an Automatic Purge Job for the Audit Trail
Scheduling an automatic purge job requires planning beforehand, such as tuning the online and archive redo log sizes. - Manually Purging the Audit Trail
You can use theDBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL
procedure to manually purge the audit trail. - Other Audit Trail Purge Operations
Other kinds of audit trail purge include enabling or disabling the audit trail purge job or setting the default audit trail purge job interval. - Example: Directly Calling a Unified Audit Trail Purge Operation
You can create a customized archive procedure to directly call a unified audit trail purge operation.
Related Topics
Parent topic: Administering the Audit Trail
28.3.1 About Purging Audit Trail Records
You can use a variety of ways to purge audit trail records.
You should periodically archive and then delete (purge) audit trail records. You can purge a subset of audit trail records or create a purge job that performs at a specified time interval. Oracle Database either purges the audit trail records that were created before the archive timestamp, or it purges all audit trail records. You can purge audit trail records in both read-write and read-only databases.
The purge process takes into account not just the unified audit trail, but audit trails from earlier releases of Oracle Database. For example, if you have migrated an upgraded database that still has operating system or XML audit records, then you can use the procedures in this section to archive and purge them.
To perform the audit trail purge tasks, you use the DBMS_AUDIT_MGMT
PL/SQL package. You must have the AUDIT_ADMIN
role before you can use the DBMS_AUDIT_MGMT
package. Oracle Database mandatorily audits all executions of the DBMS_AUDIT_MGMT
PL/SQL package procedures.
If you have Oracle Audit Vault and Database Firewall installed, the audit trail purge process differs from the procedures described in this manual. For example, Oracle Audit Vault archives the audit trail for you.
Note:
Oracle Database audits all deletions from the audit trail, without exception.
Related Topics
Parent topic: Purging Audit Trail Records
28.3.2 Selecting an Audit Trail Purge Method
You can perform the purge on a regularly scheduled basis or at a specified times.
- Purging the Audit Trail on a Regularly Scheduled Basis
You can purge all audit records, or audit records that were created before a specified timestamp, on a regularly scheduled basis. - Manually Purging the Audit Trail at a Specific Time
You can manually purge the audit records right away in a one-time operation, rather than creating a purge schedule.
Parent topic: Purging Audit Trail Records
28.3.2.1 Purging the Audit Trail on a Regularly Scheduled Basis
You can purge all audit records, or audit records that were created before a specified timestamp, on a regularly scheduled basis.
- If necessary, tune online and archive redo log sizes to accommodate the additional records generated during the audit table purge process.
- Plan a timestamp and archive strategy.
- Optionally, set an archive timestamp for the audit records.
- Create and schedule the purge job.
Related Topics
Parent topic: Selecting an Audit Trail Purge Method
28.3.2.2 Manually Purging the Audit Trail at a Specific Time
You can manually purge the audit records right away in a one-time operation, rather than creating a purge schedule.
- If necessary, tune online and archive redo log sizes to accommodate the additional records generated during the audit table purge process.
- Plan a timestamp and archive strategy.
- Optionally, set an archive timestamp for the audit records.
- Run the purge operation.
Related Topics
Parent topic: Selecting an Audit Trail Purge Method
28.3.3 Scheduling an Automatic Purge Job for the Audit Trail
Scheduling an automatic purge job requires planning beforehand, such as tuning the online and archive redo log sizes.
- About Scheduling an Automatic Purge Job
You can purge the entire audit trail, or only a portion of the audit trail that was created before a timestamp. - Step 1: If Necessary, Tune Online and Archive Redo Log Sizes
The purge process may generate additional redo logs. - Step 2: Plan a Timestamp and Archive Strategy
You must record the timestamp of the audit records before you can archive them. - Step 3: Optionally, Set an Archive Timestamp for Audit Records
If you want to delete all of the audit trail, then you can bypass this step. - Step 4: Create and Schedule the Purge Job
You can use theDBMS_AUDIT_MGMT
PL/SQL package to create and schedule the purge job.
Parent topic: Purging Audit Trail Records
28.3.3.1 About Scheduling an Automatic Purge Job
You can purge the entire audit trail, or only a portion of the audit trail that was created before a timestamp.
The individual audit records created before the timestamp can be purged.
Be aware that purging the audit trail, particularly a large one, can take a while to complete. Consider scheduling the purge job so that it runs during a time when the database is not busy.
You can create multiple purge jobs for different audit trail types, so long as they do not conflict. For example, you can create a purge job for the standard audit trail table and then the fine-grained audit trail table. However, you cannot then create a purge job for both or all types, that is, by using the DBMS_AUDIT_MGMT.AUDIT_TRAIL_DB_STD
or DBMS_AUDIT_MGMT.AUDIT_TRAIL_ALL
property. In addition, be aware that the jobs created by the DBMS_SCHEDULER
PL/SQL package do not execute on a read-only database. An automatic purge job created with DBMS_AUDIT_MGMT
uses the DBMS_SCHEDULER
package to schedule the tasks. Therefore, these jobs cannot run on a database or PDB that is open in read-only mode.
Parent topic: Scheduling an Automatic Purge Job for the Audit Trail
28.3.3.2 Step 1: If Necessary, Tune Online and Archive Redo Log Sizes
The purge process may generate additional redo logs.
-
If necessary, tune online and archive redo log sizes to accommodate the additional records generated during the audit table purge process.
In a unified auditing environment, the purge process does not generate as many redo logs as in a mixed mode auditing environment, so if you have migrated to unified auditing, then you may want to bypass this step.
See Also:
Oracle Database Administrator’s Guide for more information about tuning log files
Parent topic: Scheduling an Automatic Purge Job for the Audit Trail
28.3.3.3 Step 2: Plan a Timestamp and Archive Strategy
You must record the timestamp of the audit records before you can archive them.
-
To find the timestamp date, query the
DBA_AUDIT_MGMT_LAST_ARCH_TS
data dictionary view.
Later on, when the purge takes place, Oracle Database purges only the audit trail records that were created before the date of this archive timestamp.
After you have timestamped the records, you are ready to archive them.
28.3.3.4 Step 3: Optionally, Set an Archive Timestamp for Audit Records
If you want to delete all of the audit trail, then you can bypass this step.
You can set a timestamp for when the last audit record was archived. Setting an archive timestamp provides the point of cleanup to the purge infrastructure. If you are setting a timestamp for a read-only database, then you can use the DBMS_AUDIT.MGMT.GET_LAST_ARCHIVE_TIMESTAMP
function to find the last archive timestamp that was configured for the instance on which it was run. For a read-write database, you can query the DBA_AUDIT_MGMT_LAST_ARCH_TS
data dictionary view.
To find the last archive timestamps for the unified audit trail, you can query the DBA_AUDIT_MGMT_LAST_ARCH_TS
data dictionary view. After you set the timestamp, all audit records in the audit trail that indicate a time earlier than that timestamp are purged when you run the DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL
PL/SQL procedure. If you want to clear the archive timestamp setting, see Clearing the Archive Timestamp Setting.
If you are using Oracle Database Real Application Clusters, then use Network Time Protocol (NTP) to synchronize the time on each computer where you have installed an Oracle Database instance. For example, suppose you set the time for one Oracle RAC instance node at 11:00:00 a.m. and then set the next Oracle RAC instance node at 11:00:05. As a result, the two nodes have inconsistent times. You can use Network Time Protocol (NTP) to synchronize the times for these Oracle RAC instance nodes.
To set the timestamp for the purge job:
Parent topic: Scheduling an Automatic Purge Job for the Audit Trail
28.3.3.5 Step 4: Create and Schedule the Purge Job
You can use the DBMS_AUDIT_MGMT
PL/SQL package to create and schedule the purge job.
-
Create and schedule the purge job by running the
DBMS_AUDIT_MGMT.CREATE_PURGE_JOB
PL/SQL procedure.For example:
CONNECT aud_admin@hrpdb Enter password: password Connected. BEGIN DBMS_AUDIT_MGMT.CREATE_PURGE_JOB ( AUDIT_TRAIL_TYPE => DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED, AUDIT_TRAIL_PURGE_INTERVAL => 12, AUDIT_TRAIL_PURGE_NAME => 'Audit_Trail_PJ', USE_LAST_ARCH_TIMESTAMP => TRUE, CONTAINER => DBMS_AUDIT_MGMT.CONTAINER_CURRENT); END; /
In this example:
-
AUDIT_TRAIL_TYPE
: Specifies the audit trail type.DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED
sets it for the unified audit trail.For upgraded databases that still have audit data from previous releases:
-
DBMS_AUDIT_MGMT.AUDIT_TRAIL_AUD_STD
is used for the standard audit trail table,AUD$
. (This setting does not apply to read-only databases.) -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_FGA_STD
is used for the fine-grained audit trail table,FGA_LOG$
. (This setting does not apply to read-only databases.) -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_DB_STD
is used for both standard and fine-grained audit trail tables. (This setting does not apply to read-only databases.) -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_OS
is used for the operating system audit trail files with the.aud
extension. (This setting does not apply to Windows Event Log entries.) -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_XML
is used for the XML operating system audit trail files. -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_FILES
is used for both operating system and XML audit trail files. -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_ALL
is used for all audit trail records, that is, both database audit trail and operating system audit trail types. (This setting does not apply to read-only databases.)
To purge records from the
AUDSYS.AUD$UNIFIED
table or from the operating system spillover files:-
DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED_TABLE
purges records from theAUDSYS.AUD$UNIFIED
table. -
DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED_FILES
purges records from the operating system spillover files in each database (primary or standby).
-
-
AUDIT_TRAIL_PURGE_INTERVAL
specifies the hourly interval for this purge job to run. The timing begins when you run theDBMS_AUDIT_MGMT.CREATE_PURGE_JOB
procedure, in this case, 12 hours after you run this procedure. Later on, if you want to update this value, run theDBMS_AUDIT_MGMT.SET_PURGE_JOB_INTERVAL
procedure. -
USE_LAST_ARCH_TIMESTAMP
accepts either of the following settings:-
TRUE
deletes audit records created before the last archive timestamp. To check the last recorded timestamp, query theLAST_ARCHIVE_TS
column of theDBA_AUDIT_MGMT_LAST_ARCH_TS
data dictionary view for read-write databases and theDBMS_AUDIT_MGMT.GET_LAST_ARCHIVE_TIMESTAMP
function for read-only databases. The default value isTRUE
. Oracle recommends that you setUSE_LAST_ARCH_TIMESTAMP
toTRUE
. -
FALSE
deletes all audit records without considering last archive timestamp. Be careful about using this setting, in case you inadvertently delete audit records that should not have been deleted.
-
-
CONTAINER
is used for a multitenant environment to define where to create the purge job. If you setCONTAINER
toDBMS_AUDIT_MGMT.CONTAINER_CURRENT
, then it is available, visible, and managed only from the current PDB. TheDBMS_AUDIT_MGMT.CONTAINER_ALL
setting creates the job in the root. This defines the job as a global job, which runs according to the defined job schedule. When the job is invoked, it cleans up audit trails in all the PDBs in the multitenant environment. If you create the job in the root, then it is visible only in the root. Hence, you can enable, disable, and drop it from the root only.
Parent topic: Scheduling an Automatic Purge Job for the Audit Trail
28.3.4 Manually Purging the Audit Trail
You can use the DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL
procedure to manually purge the audit trail.
- About Manually Purging the Audit Trail
You can manually purge the audit trail right away, without scheduling a purge job. - Using DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL to Manually Purge the Audit Trail
After you complete preparatory steps, you can use theDBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL
procedure to manually purge the audit trail.
Parent topic: Purging Audit Trail Records
28.3.4.1 About Manually Purging the Audit Trail
You can manually purge the audit trail right away, without scheduling a purge job.
Similar to a purge job, you can purge audit trail records that were created before an archive timestamp date or all the records in the audit trail. Only the current audit directory is cleaned up when you run this procedure.
For upgraded databases that may still have audit trails from earlier releases, note the following about the DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL
PL/SQL procedure:
-
On Microsoft Windows, because the
DBMS_AUDIT_MGMT
package does not support cleanup of Windows Event Viewer, setting theAUDIT_TRAIL_TYPE
property toDBMS_AUDIT_MGMT.AUDIT_TRAIL_OS
has no effect. This is because operating system audit records on Windows are written to Windows Event Viewer. TheDBMS_AUDIT_MGMT
package does not support this type of cleanup operation. -
On UNIX platforms, if you had set the
AUDIT_SYSLOG_LEVEL
initialization parameter, then Oracle Database writes the operating system log files to syslog files. (Be aware that when you configure the use of syslog files, the messages are sent to the syslog daemon process. The syslog daemon process does not return an acknowledgement to Oracle Database indicating a committed write to the syslog files.) If you set theAUDIT_TRAIL_TYPE
property toDBMS_AUDIT_MGMT.AUDIT_TRAIL_OS
, then the procedure only removes.aud
files under audit directory (This directory is specified by theAUDIT_FILE_DEST
initialization parameter).
Parent topic: Manually Purging the Audit Trail
28.3.4.2 Using DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL to Manually Purge the Audit Trail
After you complete preparatory steps, you can use the DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL
procedure to manually purge the audit trail.
Parent topic: Manually Purging the Audit Trail
28.3.5 Other Audit Trail Purge Operations
Other kinds of audit trail purge include enabling or disabling the audit trail purge job or setting the default audit trail purge job interval.
- Enabling or Disabling an Audit Trail Purge Job
TheDBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure enables or disables an audit trail purge job. - Setting the Default Audit Trail Purge Job Interval for a Specified Purge Job
You can set a default purge operation interval, in hours, that must pass before the next purge job operation takes place. - Deleting an Audit Trail Purge Job
You can delete existing audit trail purge jobs. - Clearing the Archive Timestamp Setting
TheDBMS_AUDIT_MGMT.CLEAR_LAST_ARCHIVE_TIMESTAMP
procedure can clear the archive timestamp setting.
Parent topic: Purging Audit Trail Records
28.3.5.1 Enabling or Disabling an Audit Trail Purge Job
The DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure enables or disables an audit trail purge job.
In a multitenant environment, where you run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure depends on the location of the purge job, which is determined by the CONTAINER
parameter of the DBMS_MGMT.CREATE_PURGE_JOB
procedure. If you had set CONTAINER
to CONTAINER_ALL
(to create the purge job in the root), then you must run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure from the root. If you had set CONTAINER
to CONTAINER_CURRENT
, then you must run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure from the PDB in which it was created.
-
To enable or disable an audit trail purge job, use the
DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
PL/SQL procedure.For example, assuming that you had created the purge job in a the
hrpdb
PDB:CONNECT aud_admin@hrpdb Enter password: password Connected. BEGIN DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS( AUDIT_TRAIL_PURGE_NAME => 'Audit_Trail_PJ', AUDIT_TRAIL_STATUS_VALUE => DBMS_AUDIT_MGMT.PURGE_JOB_ENABLE); END; /
In this example:
-
AUDIT_TRAIL_PURGE_NAME
specifies a purge job calledAudit_Trail_PJ
. To find existing purge jobs, query theJOB_NAME
andJOB_STATUS
columns of theDBA_AUDIT_MGMT_CLEANUP_JOBS
data dictionary view. -
AUDIT_TRAIL_STATUS_VALUE
accepts either of the following properties:-
DBMS_AUDIT_MGMT.PURGE_JOB_ENABLE
enables the specified purge job. -
DBMS_AUDIT_MGMT.PURGE_JOB_DISABLE
disables the specified purge job.
-
Parent topic: Other Audit Trail Purge Operations
28.3.5.2 Setting the Default Audit Trail Purge Job Interval for a Specified Purge Job
You can set a default purge operation interval, in hours, that must pass before the next purge job operation takes place.
DBMS_AUDIT_MGMT.CREATE_PURGE_JOB
procedure takes precedence over this setting.
-
To set the default audit trail purge job interval for a specific purge job, run the
DBMS_AUDIT_MGMT.SET_PURGE_JOB_INTERVAL
procedure.For example, assuming that you had created the purge job in the
hrpdb
PDB:CONNECT aud_admin@hrpdb Enter password: password Connected. BEGIN DBMS_AUDIT_MGMT.SET_PURGE_JOB_INTERVAL( AUDIT_TRAIL_PURGE_NAME => 'Audit_Trail_PJ', AUDIT_TRAIL_INTERVAL_VALUE => 24); END; /
In this example:
-
AUDIT_TRAIL_PURGE_NAME
specifies the name of the audit trail purge job. To find a list of existing purge jobs, query theJOB_NAME
andJOB_STATUS
columns of theDBA_AUDIT_MGMT_CLEANUP_JOBS
data dictionary view. -
AUDIT_TRAIL_INTERVAL_VALUE
updates the default hourly interval set by theDBMS_AUDIT_MGMT.CREATE_PURGE_JOB
procedure. Enter a value between1
and999
. The timing begins when you run the purge job.
In a multitenant environment, where you run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_INTERVAL
procedure depends on the location of the purge job, which is determined by the CONTAINER
parameter of the DBMS_MGMT.CREATE_PURGE_JOB
procedure. If you had set CONTAINER
to CONTAINER_ALL
, then the purge job exists in the root, so you must run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure from the root. If you had set CONTAINER
to CONTAINER_CURRENT
, then you must run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_INTERVAL
procedure from the PDB in which it was created.
Parent topic: Other Audit Trail Purge Operations
28.3.5.3 Deleting an Audit Trail Purge Job
You can delete existing audit trail purge jobs.
To find existing purge jobs, query the JOB_NAME
and JOB_STATUS
columns of the DBA_AUDIT_MGMT_CLEANUP_JOBS
data dictionary view.
-
To delete an audit trail purge job, use the
DBMS_AUDIT_MGMT.DROP_PURGE_JOB
PL/SQL procedure.
For example, assuming that you had created the purge job in the hrpdb
PDB:
CONNECT aud_admin@hrpdb
Enter password: password
Connected.
BEGIN
DBMS_AUDIT_MGMT.DROP_PURGE_JOB(
AUDIT_TRAIL_PURGE_NAME => 'Audit_Trail_PJ');
END;
/
In a multitenant environment, where you run the DBMS_AUDIT_MGMT.DROP_PURGE_JOB
procedure depends on the location of the purge job, which is determined by the CONTAINER
parameter of the DBMS_MGMT.CREATE_PURGE_JOB
procedure. If you had set CONTAINER
to CONTAINER_ALL
, then the purge job exists in the root, so you must run the DBMS_AUDIT_MGMT.SET_PURGE_JOB_STATUS
procedure from the root. If you had set CONTAINER
to CONTAINER_CURRENT
, then you must run the DBMS_AUDIT_MGMT.DROP_PURGE_JOB_INTERVAL
procedure from the PDB in which it was created.
Parent topic: Other Audit Trail Purge Operations
28.3.5.4 Clearing the Archive Timestamp Setting
The DBMS_AUDIT_MGMT.CLEAR_LAST_ARCHIVE_TIMESTAMP
procedure can clear the archive timestamp setting.
To find a history of audit trail log cleanup, you can query the UNIFIED_AUDIT_TRAIL
data dictionary view, using the following criteria: OBJECT_NAME
is DBMS_AUDIT_MGMT
, OBJECT_SCHEMA
is SYS
, and SQL_TEXT
is set to LIKE %DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL%
.
-
To clear the archive timestamp setting, use the
DBMS_AUDIT_MGMT.CLEAR_LAST_ARCHIVE_TIMESTAMP
PL/SQL procedure to specify the audit trail type and for a multitenant environment, the container type.For example, assuming that you had created the purge job in the
hrpdb
PDB:CONNECT aud_admin@hrpdb Enter password: password Connected. BEGIN DBMS_AUDIT_MGMT.CLEAR_LAST_ARCHIVE_TIMESTAMP( AUDIT_TRAIL_TYPE => DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED, CONTAINER => DBMS_AUDIT_MGMT.CONTAINER_CURRENT); END; /
In this example:
-
AUDIT_TRAIL_TYPE
is set for the unified audit trail. If theAUDIT_TRAIL_TYPE
property is set toDBMS_AUDIT_MGMT.AUDIT_TRAIL_OS
orDBMS_AUDIT_MGMT.AUDIT_TRAIL_XML
, then you cannot setRAC_INSTANCE_NUMBER
to0
. You can omit theRAC_INSTANCE_NUMBER
setting if you setAUDIT_TRAIL_TYPE
toDBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED
.You can clear the archive timestamps from the
AUDSYS.AUD$UNIFIED
table by settingDBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED_TABLE
. To clear the archive timestamps from the operating system spillover files in each database (primary or standby), setDBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED_FILES
. -
CONTAINER
applies the timestamp to a multitenant environment.DBMS_AUDIT_MGMT.CONTAINER_CURRENT
specifies the local PDB;DBMS_AUDIT_MGMT.CONTAINER_ALL
applies to all databases.
Parent topic: Other Audit Trail Purge Operations
28.3.6 Example: Directly Calling a Unified Audit Trail Purge Operation
You can create a customized archive procedure to directly call a unified audit trail purge operation.
The pseudo code in Example 28-1 creates a database audit trail purge operation that the user calls by invoking the DBMS_ADUIT.CLEAN_AUDIT_TRAIL
procedure for the unified audit trail.
The purge operation deletes records that were created before the last archived timestamp by using a loop. The loop archives the audit records, calculates which audit records were archived and uses the SetCleanUpAuditTrail
call to set the last archive timestamp, and then calls the CLEAN_AUDIT_TRAIL
procedure. In this example, major steps are in bold typeface.
Example 28-1 Directly Calling a Database Audit Trail Purge Operation
-- 1. Set the last archive timestamp: PROCEDURE SetCleanUpAuditTrail() BEGIN CALL FindLastArchivedTimestamp(AUD$); DBMS_AUDIT_MGMT.SET_LAST_ARCHIVE_TIMESTAMP( AUDIT_TRAIL_TYPE => DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED, LAST_ARCHIVE_TIME => '23-AUG-2013 12:00:00', CONTAINER => DBMS_AUDIT_MGMT.CONTAINER_CURRENT); END; / -- 2. Run a customized archive procedure to purge the audit trail records: BEGIN CALL MakeAuditSettings(); LOOP (/* How long to loop*/) -- Invoke function for audit record archival CALL DoUnifiedAuditRecordArchival(); CALL SetCleanUpAuditTrail(); IF(/* Clean up is needed immediately */) DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL( AUDIT_TRAIL_TYPE => DBMS_AUDIT_MGMT.AUDIT_TRAIL_UNIFIED, USE_LAST_ARCH_TIMESTAMP => TRUE, CONTAINER => DBMS_AUDIT_MGMT.CONTAINER_CURRENT ); END IF END LOOP /*LOOP*/ END; /* PROCEDURE */ /
Parent topic: Purging Audit Trail Records
28.4 Audit Trail Management Data Dictionary Views
Oracle Database provides data dictionary views that list information about audit trail management settings.
Table 28-2 lists these views.
Table 28-2 Views That Display Information about Audit Trail Management Settings
View | Description |
---|---|
|
Displays the history of purge events of the traditional (that is, non-unified) audit trails. Periodically, as a user who has been granted the DELETE FROM DBA_AUDIT_MGMT_CLEAN_EVENTS; This view applies to read-write databases only. For read-only databases, a history of purge events is in the alert log. For unified auditing, you can find a history of purged events by querying the |
|
Displays the currently configured audit trail purge jobs |
|
Displays the currently configured audit trail properties that are used by the |
|
Displays the last archive timestamps that have set for audit trail purges |
Related Topics
Parent topic: Administering the Audit Trail