温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

查杀oracle正在执行的job:job broken后,job的total time还在增长

发布时间:2020-08-07 16:01:38 来源:ITPUB博客 阅读:550 作者:xjwang666 栏目:关系型数据库

原帖地址 http://blog.csdn.net/flower_xixi/article/details/26373871
1.首先确定要停止的JOB号

select * from dba_jobs_running;--得到sid和job号

2.Broken你确认的JOB

可以在PL/SQL Developer中,直接选项broken;或者使用语句:

EXEC DBMS_JOB.BROKEN(job#,TRUE);--加入job号,注意commit

3.Kill 对应的Oracle Session

select * from v$session where sid='97' --根据sid号,得到SERIAL#

找到该job的对应SESSION(SID,SERIAL#),然后执行以下命令:

--ALTER SYSTEM KILL SESSION 'sid,serial#';

-- 如果使用ALTER SYSTEM KILL SESSION执行很长时间,其实可以使用OS的命令来快速KILL掉SESSION.步骤如下:

select * from v$session where sid='97'--根据sid号,得到paddr
select * from v$process where addr='6C8F14C4'    -- 加入paddr的值,得到spid的值,杀命令时用

 
     For Windows, at the DOS Prompt: orakill oraclesid spid--注意oraclesid为数据库实例名
     For UNIX at the command line> kill –9 spid

4.检查你的JOB是否还在运行

检查你要停止的JOB是否还在运行,其实多数情况下,应该都已经停止了。尤其执行的第三步的“杀手”命令。

如果真的还是没有停止,而且dba_jobs_running已经查不到该job了,则执行以下步骤;

5.select name,value from v$parameter where name ='job_queue_processes'; 
将Job Queue Processes的数目修改为0
ALTER SYSTEM SET job_queue_processes = 0;

job_queue_processes取值范围为0到1000,总共可创建多少个job进程由job_queue_processes参数来决定。

注:当Job Queue Processes的数目为0,所有的JOB都会停止。

6.修改你要修改的任何东西,甚至是JOB内的内容。将job执行的所有东西注掉,写return;否则不能编译

也可以将job里调用的所有存储过程内容都注掉,写return;编译。

7.修改完成后,将job的BROKEN状态停止。

SQL>EXEC DBMS_JOB.BROKEN(job#,FALSE);  --必须 commit

或者在PL/SQL Developer图形界面上操作,也一样;将job重新启起来。

8.恢复job_queue_processes的原始值

ALTER SYSTEM SET job_queue_processes = 10;

此时刷新几次job,total time一会儿就会停止增长。job彻底停止。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI