[Oracle] Scheduler和Job

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是如何交互的?

[Oracle] Scheduler和Job_第1张图片

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

Scheduler架构

[Oracle] Scheduler和Job_第2张图片

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

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

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

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



你可能感兴趣的:(oracle,job,scheduler)