JCL

Материал из свободной русской энциклопедии «Традиция»
Перейти к: навигация, поиск

Job Control Language (JCL)язык программирования, применяющийся в операционных системах мейнфреймов фирмы IBM линии OS/360 и MVS и их клонах, включая ОС ЕС. (В линии DOS/360 реализована частично совместимая версия JCL).

Применяется для управления запуском заданий, выполняющихся в пакетном режиме. В силу функционального назначения, обладает минимальными выразительными свойствами собственно, как язык программирования.

Синтаксис оператора исходно был жестко привязан к определенных позициям (колонкам) на перфоркарте:

  • в первых колонках — признак типа карты:
    • // — карта оператора. Карта содержащая только символы // в начальных позициях — пустой оператор. Пустой оператор указывает на завершение описания задания.
    • /* — конец данных вводимых во входном потоке,
    • //* — строка комментариев
  • Если это карта оператора то далее может идти имя оператора (до 8 символов). Это имя используется для ссылок на данный оператор из других операторов, а так же для идентификации оператора в сообщениях ОС. Имя оператора JOB является именем задания в системе.
  • затем через как минимум один пробел (в ранних версиях — строго с 10-й колонки) следует оператор языка:
    • JOB — описание задания
    • EXEC — описание шага задания
    • DD — описание используемого в шаге задания набора данных или устройства ввода-вывода (по одному оператору на каждый используемый ресурс).
  • затем через как минимум один пробел идут параметры оператора, перечисляемые через запятую. Пробелы между параметрами не допустимы. Если параметры не умещаются на одной карте с оператором, они могут быть продолжены на картах продолжения. В ранних версиях для указания наличия карт продолжения нужно было указать в 71-й колонке символ отличный от пробела (обычно это была латинская буква X), а список параметров на карте продолжения должен был начинаться строго с 16-й колонки. В более современных версиях достаточно отделить параметры хотя бы одним пробелом от начальных //.
  • Колонки с 72-й по 80 отводились под нумерацию карт для предотвращения нарушения порядка карт.

Этот синтаксис остался с тех времён, когда задание вводилось с перфокарт (80 колоночных) и позволяет предохранить от случайного запуска на выполнение информации с неправильно вставленных (перевёрнутых) карт.


В целях обеспечения совместимости он не менялся с 1960 гг. и продолжает применяться даже в современных версиях операционных систем z/OS и DOS/VSE.

Пример[править]

Эта последовательность команд («задание» в терминах ОС ЕС) копирует содержимое набора данных IS198.TEST.INPUT в набор данных IS198.TEST.OUTPUT.

//IS198CPY JOB (IS198T30500),'COPY JOB',CLASS=L,MSGCLASS=X
//COPY01   EXEC PGM=IEBGENER
//SYSPRINT DD  SYSOUT=*
//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) и выходной поток (SYSPRINT). Оператор JOB описывает учетную информацию пользователя (формат зависит от настроек системы) и параметры выполнения задания. В данном примере задание выполняется с классом L (параметры класса определяет системный администратор при настройке ОС), служебные сообщения будут выводиться в выходную очередь класса X.

В юниксоподобной системе аналогичное действие выглядело бы как

cp IS198.TEST.INPUT IS198.TEST.OUTPUT

Следует однако иметь в виду, что «задание» в терминах «традиционных» ОС для mainframe всё же не является прямым аналогом командного файла в юниксоподобной системе. Обработка заданий выполняется специальной системной программой — Планировщиком заданий. Так как язык управления заданиями описывает не только порядок выполнения определенных программ, но и все необходимые для этого ресурсы (имена наборов данных и место под них, устройства ввода-вывода, требования к оперативной памяти и времени центрального процессора и т.д.), Планировщик может так организовать порядок выполнения заданий что будет обеспечена наиболее эффективное использование доступных вычислительных ресурсов с минимальных вмешательством человека-оператора.