Язык управления заданиями
Язык управления заданиями (англ. Job Control Language, JCL) — язык программирования, применяющийся в операционных системах мейнфреймов фирмы IBM линии OS/360, MVS, OS/390, z/OS и их клонах, включая ОС ЕС, TKS и БОС. В линии IBM DOS/360, DOS/VS, VSE, z/VSE реализована частично совместимая версия JCL. В гостевой ОС IBM GCS реализовано подмножество JCL.
Применяется для управления запуском пакетных заданий. В силу функционального назначения, обладает минимальными выразительными свойствами как, собственно, язык программирования.
Синтаксис оператора исходно был жестко привязан к определенным позициям (колонкам) на перфокарте:
- в первых колонках — признак типа карты:
//
— карта оператора. Карта, содержащая только символы // в начальных позициях — пустой оператор. Пустой оператор указывает на завершение описания задания./*
— конец данных, вводимых во входном потоке,//*
— строка комментариев
- Если это карта оператора, то далее может идти имя оператора (до 8 символов). Это имя используется для ссылок на данный оператор из других операторов, а также для идентификации оператора в сообщениях ОС. Имя оператора JOB является именем задания в системе.
- затем через как минимум один пробел (в ранних версиях — строго с 10-й колонки) следует оператор языка:
JOB
— описание заданияEXEC
— описание шага заданияDD
— описание используемого в шаге задания набора данных или устройства ввода-вывода (по одному оператору на каждый используемый ресурс).
- затем через как минимум один пробел идут параметры оператора, перечисляемые через запятую. Пробелы между параметрами недопустимы. Если параметры не умещаются на одной карте с оператором, они могут быть продолжены на картах продолжения. В ранних версиях для указания наличия карт продолжения нужно было указать в 71-й колонке символ, отличный от пробела (обычно это была латинская буква
X
), а список параметров на карте продолжения должен был начинаться строго с 16-й колонки. В более современных версиях достаточно отделить параметры хотя бы одним пробелом от начальных //. - Колонки с 72-й по 80 отводились под нумерацию карт для предотвращения нарушения порядка карт.
Этот синтаксис остался с тех времён, когда задание вводилось с перфокарт (80-колоночных) и позволяет предохранить от случайного запуска на выполнение информации с неправильно вставленных (перевёрнутых) карт.
В целях обеспечения совместимости он не менялся с 1960 гг. и продолжает применяться в современных версиях операционных систем z/OS и z/VSE.
Пример
Эта последовательность команд («задание» в терминах ОС ЕС) копирует содержимое набора данных IS198.TEST.INPUT
в набор данных IS198.TEST.OUTPUT
.
//IS198CPY JOB (IS198T3*0500),'COPY JOB',CLASS=L,MSGCLASS=X
//COPY01 EXEC PGM=IEBGENER
//SYSPRINT DD SYSOUT=A
//SYSUT1 DD DSN=IS198.TEST.INPUT,DISP=SHR
//SYSUT2 DD DSN=IS198.TEST.OUTPUT,
// DISP=(NEW,CATLG,DELETE),
// SPACE=(CYL,(40,5),RLSE),
// DCB=(LRECL=115,BLKSIZE=0),
// DATACLAS=SEQFB
//SYSIN DD DUMMY
//
Копирование осуществляет служебная программа IEBGENER
, которая копирует входной набор данных (SYSUT1
) в выходной набор данных (SYSUT2
).
Для нового (DISP=(NEW,CATLG,DELETE)
) выходного набора данных будет выделено место (параметр SPACE
) на устройстве прямого доступа: 40 цилиндров изначально и 15 раз по 5 цилиндров, когда первоначально выделенное место будет израсходовано. При успешном завершении задания новый набор данных будет каталогизирован (DISP=(NEW,CATLG,DELETE
), а в случае аварийного завершения — удален (DISP=(NEW,CATLG,DELETE)
)
Кроме того, у программы есть входной поток (SYSIN
- не используется (DUMMY)) и выходной поток (SYSPRINT
).
Оператор JOB
описывает учетную информацию пользователя (формат зависит от настроек системы) и параметры выполнения задания. В данном примере задание выполняется с классом L
(параметры класса определяет системный администратор при настройке ОС), служебные сообщения будут выводиться в выходную очередь класса A
. Имя, заданное в качестве метки оператора JOB (IS198CPY), будет использовано в качестве идентификатора задания во время его выполнения.
В юниксоподобной системе аналогичное действие выглядело бы как
cp IS198.TEST.INPUT IS198.TEST.OUTPUT
Следует однако иметь в виду, что «задание» в терминах «традиционных» ОС для mainframe всё же не является прямым аналогом командного файла в юниксоподобной системе. Обработка заданий выполняется специальной системной программой — Планировщиком заданий. Так как язык управления заданиями описывает не только порядок выполнения определенных программ, но и все необходимые для этого ресурсы (имена наборов данных и место под них, устройства ввода-вывода, требования к оперативной памяти и времени центрального процессора и т.д.). Планировщик организовывает порядок выполнения заданий так, чтобы наиболее эффективно использовать доступные вычислительные ресурсы с минимальным вмешательством человека-оператора.