当job_queue_processes=0 时,cjq 进程依然启动
适用于
oracle server 企业版 10.2.0.1 and later
症状:
当job_queue_processes=0 时, cjq 进程被启动。
文档
上说:
如果初始化参数job_queue_processes=0,协调器进程(coordinator process)不会被启动。
原因:
这是期望的行为,只要有定义并且活动(active)的scheduler jobs.
从这个文档中有如下的记载
--->额外注意:上面的这个链接打不开
如果初始化参数被设置为0 ,或者根本就没有设置,那么DBMS_JOB jobs 是不会运行的。
但是,自动启动和停止特性将会被所有的DBMS_SCHEDULER jobs and windows 使用。
如果有DBMS_SCHEDULER job 被执行,the coordinator进程将会被启动,进而 job将会被执行。
--->注意:DBMS_JOB jobs 和 DBMS_SCHEDULER job 是不同的job类型。
解决方案:
若是绝对需要,job可以被disabled掉:
BEGIN
FOR job_rec IN (SELECT job_name FROM dba_scheduler_jobs) LOOP
DBMS_SCHEDULER.DISABLE(job_rec.job_name);
END LOOP;
END;
/
然而,这不是推荐的方法,除非为了测试 当 job_queue_processes=0 的情况下 启动database 时,cjq进程的启动。
--->注意:cjq 是coordinator job queue进程的缩写。