開啓審計參數 SQL> show parameter audit NAME TYPE VALUE ----------------------------------------------- ------------------------------ audit_file_dest string /u01/app/oracle/admin/mydb/adump audit_sys_operations boolean FALSE audit_syslog_level string audit_trail string NONE SQL> alter system setaudit_trail=db,extended scope=spfile; 2、重啓數據庫 靜態參數,爲了使參數生效,須要重啓數據庫 SQL> shutdown immediate; Database closed. Database dismounted. ORACLE instance shut down. SQL> startup ORACLE instance started. Total System Global Area 599785472 bytes Fixed Size 2085776 bytes Variable Size 192941168 bytes Database Buffers 398458880 bytes Redo Buffers 6299648 bytes Database mounted. Database opened. SQL> show parameter audit NAME TYPE VALUE ----------------------------------------------- ------------------------------ audit_file_dest string /u01/app/oracle/admin/mydb/adump audit_sys_operations boolean FALSE audit_syslog_level string audit_trail string DB, EXTENDED 3、設置對錶進行審計 這樣每次有用戶對錶進行操做,那麼都會有相應的記錄被添加到aud$中,而Oracle爲了方便讀取數據,建立了視圖。 雖然會記錄每一個用戶對錶的操做,可是不會記錄sys用戶的操做,其餘全部用戶都會作記錄。 SQL> conn / as sysdba Connected. SQL> audit all on zx.num_t by accesswhenever successful; Audit succeeded. SQL> set linesize 200 SQL> select * from dba_obj_audit_opts; OWNER OBJECT_NAME OBJECT_TYPE ALT AUD COM DEL GRA IND INS LOC REN SEL UPD REF EXE CRE REA WRI FBK ------------------------------------------------------------ ----------------- ----- ----- ----- ----- ---------- ----- ----- ----- ----- ----- --- ----- ----- ----- ----- ----- ZX NUM_T TABLE A/- A/- A/- A/- A/- A/- A/- A/- A/- A/- A/- -/- -/- -/- -/- -/- A/- 前面列中 A表示access,每次被審計的操做都會記錄,好比開啓了scott.emp的select審計,那麼任何人select這張表都會觸發一次審計,而且記錄在aud$中。 S表示session,每一個會話被審計的操做都記錄一次。 使用不一樣用戶對zx.num_t表作不一樣訪問: SQL> conn zx/zx Connected. SQL> select count(*) from zx.num_t; COUNT(*) ---------- 0 SQL> insert into zx.num_t (id1)values(1); 1 row created. SQL> commit; Commit complete. SQL> conn scott/tiger Connected. SQL> select count(*) from zx.num_t; COUNT(*) ---------- 1 SQL> delete from zx.num_t; 1 row deleted. SQL> commit; Commit complete. SQL> insert into zx.num_t (id2)values(2); 1 row created. SQL> rollback; Rollback complete. 4、查詢審計記錄 SQL> alter session setnls_date_format='yyyymmdd hh24:mi:ss'; Session altered. SQL> set lines 200 col OS_USERNAME for a10 col USERNAME for a11 col USERHOST for a10 col TERMINAL for a10 col TIMESTAMP for a20 col obj_name for a10 col OWNER for a10 col ACTION_NAME for a11 col TRANSACTIONID for a16 col sql_text for a50 SELECT USERNAME, USERHOST, TIMESTAMP, OWNER, OBJ_NAME, ACTION_NAME, SQL_TEXT FROM DBA_AUDIT_TRAIL WHERE OBJ_NAME='NUM_T' ORDER BY TIMESTAMP; USERNAME USERHOST TIMESTAMP OWNER OBJ_NAME ACTION_NAME SQL_TEXT ----------- ---------- ------------------------------ ---------- ------------------------------------------------------------- ZX rhel5 20161107 11:57:55 ZX NUM_T NOAUDIT OBJ noaudit all on num_t ECT ZX rhel5 20161107 12:00:07 ZX NUM_T SELECT select count(*) from zx.num_t ZX rhel5 20161107 12:00:21 ZX NUM_T INSERT insert into zx.num_t (id1) values(1) SCOTT rhel5 20161107 12:00:37 ZX NUM_T SELECT select count(*) from zx.num_t SCOTT rhel5 20161107 12:00:45 ZX NUM_T DELETE delete from zx.num_t SCOTT rhel5 20161107 12:01:27 ZX NUM_T INSERT insert into zx.num_t (id2) values(2) 6 rows selected. 5、取消審計 SQL> noaudit all on num_t; Noaudit succeeded. 6、清空aud$ 這張系統表是能夠使用TRUNCATE命令截斷的。把它刪掉以後那麼視圖中的記錄也就相應消失了。 SQL> truncate table aud$; SQL> SELECT * FROM DBA_FGA_AUDIT_TRAIL; no rows selected
開啓審計參數sql
2、重啓數據庫數據庫
靜態參數,爲了使參數生效,須要重啓數據庫session
3、設置對錶進行審計oracle
這樣每次有用戶對錶進行操做,那麼都會有相應的記錄被添加到aud$中,而Oracle爲了方便讀取數據,建立了視圖。app
雖然會記錄每一個用戶對錶的操做,可是不會記錄sys用戶的操做,其餘全部用戶都會作記錄。ui
前面列中spa
A表示access,每次被審計的操做都會記錄,好比開啓了scott.emp的select審計,那麼任何人select這張表都會觸發一次審計,而且記錄在aud$中。code
S表示session,每一個會話被審計的操做都記錄一次。orm
使用不一樣用戶對zx.num_t表作不一樣訪問:blog
4、查詢審計記錄
5、取消審計
6、清空aud$
這張系統表是能夠使用TRUNCATE命令截斷的。把它刪掉以後那麼視圖中的記錄也就相應消失了。