使用stream实现DML的审计功能

MARKtft 2010-02-24 05:38:29
Dear All:
Hi. 当前环境:Window XP + Oracle Database 10g Enterprise Edition Release 10.1.0.2.0
最近遇到一个需求如下:
Schema的表的DML操作记录到日志表。(例如:update t set col1 = col1+5 )。
记录到日志的信息包括: 当前用户名:schema name,DML操作类型:update,DML操作的具体列名:col1 等等。

因为DML操作的列是动态的,所以考虑使用stream的capture来捕获DML的信息。

1、已经配置stream的帐号 strmadmin
2、strmadmin 已正确授权
3、需捕获DML的schema为scott

一、登入strmadmin
1、建立队列
begin
dbms_streams_adm.set_up_queue(
queue_table => 'prod_queue_table',
queue_name => 'prod_queue',
queue_user => 'strmadmin');
end;

2、创建capture进程
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'scott',
streams_type => 'capture',
streams_name => 'capture_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;

3、创建apply进程
begin
dbms_streams_adm.add_schema_rules(
schema_name => 'scott',
streams_type => 'apply',
streams_name => 'apply_prod',
queue_name => 'strmadmin.prod_queue',
include_dml => true,
include_ddl => true,
include_tagged_lcr => false,
source_database => null,
inclusion_rule => true);
end;

4、启动capture进程
begin
dbms_capture_adm.start_capture(capture_name => 'capture_prod');
end;

5、启动apply进程
begin
dbms_apply_adm.start_apply(apply_name => 'apply_prod');
end;

6、设置DML操作的Handler
begin
dbms_apply_adm.set_dml_handler(
object_name => 'scott.dept',
object_type => 'TABLE',
operation_name => 'UPDATE',
error_handler => false,
user_procedure => 'strmadmin.dml_handler',
apply_database_link => null);
end;

问题1:
在步骤6中的 “user_procedure => 'strmadmin.dml_handler' ”。
我已经在strmadmin中建立了一个存储过程dml_handler,用来处理scott的dept的DML操作(UPDATE操作)。

测试中,对scott的dept表,进行UPDATA操作后,发现dml_handler没有被调用。
在dml_handler中使用dbms_output.putline('procedure had been fired!');
发现控制台并未打印出该条信息。

问题2:
在启动apply进程后,查看状态。
SELECT apply_name, apply_captured, status FROM dba_apply;
发现该进程状态为aborted.


请教大家:上面设置capture和apply的过程,是否正确。不甚感激。
...全文
104 8 打赏 收藏 举报
写回复
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
MARKtft 2010-04-07
  • 打赏
  • 举报
回复
各位不好意思,最近太忙。拖了那么久才来结帖。
公司最后决定不用STREAM来做同步了,原因是比较麻烦。
另外,似乎10G R2之后才能使用STREAM来做同步,R1不可以使用该功能。
liuyi8903 2010-03-29
  • 打赏
  • 举报
回复
怎么说呢,主要是由于stream不是太稳定,否则还是可行的。
friendjin 2010-03-29
  • 打赏
  • 举报
回复
你们真敢做啊,通过stream做dml审计不值得.
liuyi8903 2010-03-27
  • 打赏
  • 举报
回复
instantiation scn你都没有做啊。
MARKtft 2010-03-02
  • 打赏
  • 举报
回复
引用 2 楼 paladin_china 的回复:
查看dba_apply_error表


查看dba_apply_error,得到error_message如下:
ORA-26687: no instantiation SCN provided for "SCOTT"."DEPT" in source database "

请教原帖中的配置capture和apply(第一步到第六步)的步骤是否正确呢?
MARKtft 2010-03-02
  • 打赏
  • 举报
回复
最近项目赶,都时间看回复。
今天按楼上兄弟的方法去看一下。
我感觉是APPLY进程没有成功运行。
Paladin_china 2010-02-25
  • 打赏
  • 举报
回复
查看dba_apply_error表
liuyi8903 2010-02-25
  • 打赏
  • 举报
回复
捕获成功了吗?看一下message
相关推荐
发帖
Oracle 高级技术

3476

社区成员

Oracle 高级技术相关讨论专区
社区管理员
  • 高级技术社区
加入社区
帖子事件
创建了帖子
2010-02-24 05:38
社区公告
暂无公告