OGG rep运行慢的分析步骤

本文介绍了一种排查OGGrep运行缓慢的方法,通过获取rep进程PID,并进一步找到LOCAL=YES的子进程,最终通过SQL查询定位导致性能瓶颈的具体SQL语句及其执行计划。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

OGG rep运行慢的分析步骤:

第一:按照rep的进程名进行 ps -ef | grep ,获得rep的进程PID

[oracle@hosta ~]$ ps -ef | grep repfull
oracle   27906 27861  0 18:01 pts/7    S+     0:00              \_ grep repfull
oracle   27603 20773  1 17:03 ?        Ssl    0:51  \_ /u02/ggs/replicat PARAMFILE /u02/ggs/dirprm/repfull.prm REPORTFILE /u02/ggs/dirrpt/REPFULL.rpt PROCESSID REPFULL USESUBDIRS


 

第二:按照rep的进程PID 进行 ps -ef | grep,以获得27603产生的LOCAL=YES的进程

[oracle@hosta ~]$ ps -ef f | grep 27603  
oracle   27910 27861  0 18:01 pts/7    S+     0:00              \_ grep 27603
oracle   27603 20773  1 17:03 ?        Ssl    0:52  \_ /u02/ggs/replicat PARAMFILE /u02/ggs/dirprm/repfull.prm REPORTFILE /u02/ggs/dirrpt/REPFULL.rpt PROCESSID REPFULL USESUBDIRS
oracle   27607 27603  2 17:03 ?        Ds     1:41      \_ oracleorcl (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))   ---->这一个就是。
[oracle@hosta ~]$ 


sqlplus 里执行如下sql即可:

SELECT sql_text,sql_id FROM v$sqltext a WHERE a.hash_value = (SELECT sql_hash_value FROM v$session b 
WHERE b.SID =( select s.sid from v$session s,v$process p where s.paddr=p.addr and p.spid='27607'))   ---> 替换上27607
ORDER BY piece ASC;

 

select plan_table_output from table(dbms_xplan.display_cursor('6ufrk02y1h6u5'));  --->替换为上一步查询得到的sql_id,查看其执行计划。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值