教学文章
Technology Exchange
热门课程
400电话

免费咨询热线
400-090-9964

教学文章

Oracle的Scheduler和Job介绍

时间:2017-08-01 来源:

  Oracle Scheduler是用来管理和计划数据库的Job,通过它可以让很多常规的数据库任务自动执行,减少人为干预,解放劳动力,本质上来说,它和Linux的crontab,商业任务管理软件如Autosys, UC4一样,只是它们的领域不一样,oracle Scheduler专注于Oracle数据库Job的自动化管理、维护和监控。

  本篇是理论篇,介绍Oracle Scheduler的基本概念,Oracle Scheduler的名词很多,下面一一介绍:

  Program (程序)

  Program是指Job执行的对象,如存储过程、PL/SQL块、外部可执行程序等

  Schedule (计划)

  Schedule定义Job什么时候执行,以及执行的次数,有以下两种类似的Schedule:

  1)基于时间的计划(Time Schedule)

  2)基于事件的计划(Event Schedule)

  Destination (地点)

  Destination定义Job执行的地点,有以下两种:

  1)数据库(Database Destination):表示Job在数据库里执行(包含本地和远程的数据库)

  2)外部(External Destination):表示Job在数据库外执行

  这里有要注意的是:如果Job执行的地点在远程,则必须把Scheduler Agent安装在远程主机上。

  File Watcher(文件看守者)

  文件看守者定义目的地、文件名等属性,一旦有符合条件的文件到达便触发一个事件,启动Job

  Credential (认证)

  Credential定义了用户密码对,只有通过认证的Job才能启动,主要有以下两种认证:

  1)远程数据库认证

  2)外部认证(如操作系统)

  Chain (任务链)

  Chain用于定义一系列Job执行的依赖关系

  Window(时间窗口)

  时间窗口用于定义一天中的某个时间段内Job的资源分配情况。

  Group(组)

  一系列相同的对象组成Group,有以下三种Group:

  1)Database Destination Group

  2)External Destination Group

  3)Window Group

  Job, Program, Schedule是如何交互的?


  

上图显示了它们之间的关系,同一个Program可以被多个Job调用,同样地,多个Job可以共用同一个Schedule

  Scheduler架构


 

 如上图所示,Scheduler主要包含以下几个组件:

  1)Job Table:存放所有Job的信息,可通过视图*_scheduler_jobs查看

  2)Job Coordinator:它是一个或多个后台进程(cjqNNN),用于控制和启动Job Slave

  3)Job Slave(js):真正执行Job的进程

  (以上内容摘于网络,如有侵权,请告之,将第一时间删除)

版权所有@北京神脑资讯技术有限公司(CUUG,中国UNIX用户协会) Copyright ALL Rights Reserved 京ICP备11008061号-1

CUUG旗下网站:www.cuug.com.cn www.cuug.com oracle.cuug.com bbs.cuug.com www.cuug.net

电话:010-59426307 010-59426319 邮政编码:100089

地址:北京市海淀区北清路164号28-38号院