|
系统中有一个JOB,由于SQL编写的问题,导致运行了5个多小时还没完,我想把它kill掉。
1. 首先我找到了这个JOB对应session的SID和对应的OS JOB进程(j000等)的SPID。
- select * from gv$process s,gv$session gn where s.ADDR=gn.PADDR and gn.STATUS='ACTIVE' and gn.SCHEMANAME='A'
复制代码
2. 然后,在OS上kill对应的SPID
3. 过一分钟左右的时间,再次查询gv$session,发现此session还在,SPID变了,在OS上自动产生了一个j000进程与此session对应。
4. 将job设成broken状态,再次 kill -9 SPID。过一分钟左右此session没了,OS也没再产生新的job进程。
5. 问题来了,虽然此时session和OS进程都没有与此JOB相关的东东存在,但此JOB的运行时间(total_time)仍在不停增加。
6. 尝试解决方法:
(1)重启cjq0这个进程 无效
(2)重启DB 无效
如何解决这个total_time不停增加的问题?
请各位大虾不吝赐教,谢谢。 |
|