JCL - условная обработка

Система ввода заданий использует два подхода для выполнения условной обработки в JCL. Когда задание завершается, устанавливается код возврата в зависимости от статуса выполнения. Код возврата может быть числом от 0 (успешное выполнение) до 4095 (ненулевое значение показывает состояние ошибки). Наиболее распространенные условные значения:

  • 0 = Нормально - все ОК

  • 4 = Предупреждение - незначительные ошибки или проблемы.

  • 8 = Ошибка - существенные ошибки или проблемы.

  • 12 = серьезная ошибка - серьезные ошибки или проблемы, результатам нельзя доверять.

  • 16 = Терминальная ошибка - очень серьезные проблемы, не используйте результаты.

Выполнение шага задания можно контролировать на основе кода возврата предыдущего шага (ов) с помощью COND параметр и IF-THEN-ELSE construct, который был объяснен в этом руководстве.

COND параметр

А CONDПараметр может быть закодирован в операторе JOB или EXEC JCL. Это проверка кода возврата предыдущих шагов задания. Если тест признан истинным, выполнение текущего шага задания пропускается. Обход - это просто пропуск шага задания, а не аварийное завершение. В одном тесте может быть объединено не более восьми условий.

Синтаксис

Ниже приведен основной синтаксис параметра JCL COND:

COND=(rc,logical-operator)
or
COND=(rc,logical-operator,stepname)
or
COND=EVEN
or 
COND=ONLY

Вот описание используемых параметров:

  • rc : Это код возврата

  • logical-operator : Это может быть GT (больше или равно), GE (больше или равно), EQ (равно), LT (меньше), LE (меньше или равно) или NE (не равно).

  • stepname : Это шаг задания, код возврата которого используется в тесте.

Последние два условия (a) COND = EVEN и (b) COND = ONLY были объяснены ниже в этом руководстве.

COND можно закодировать либо внутри оператора JOB, либо внутри оператора EXEC, и в обоих случаях он ведет себя по-разному, как описано ниже:

COND в заявлении JOB

Когда COND закодирован в операторе JOB, условие проверяется для каждого шага задания. Если условие выполняется на каком-либо конкретном этапе задания, оно игнорируется вместе с последующими этапами задания. Ниже приводится пример:

//CNDSAMP JOB CLASS=6,NOTIFY=&SYSUID,COND=(5,LE)
//*
//STEP10 EXEC PGM=FIRSTP  
//* STEP10 executes without any test being performed.

//STEP20 EXEC PGM=SECONDP 
//* STEP20 is bypassed, if RC of STEP10 is 5 or above. 
//* Say STEP10 ends with RC4 and hence test is false. 
//* So STEP20 executes and lets say it ends with RC16.

//STEP30 EXEC PGM=SORT
//* STEP30 is bypassed since 5 <= 16.

COND внутри оператора EXEC

Когда COND закодирован в операторе EXEC шага задания и оказывается истинным, то пропускается только этот шаг задания, и выполнение продолжается со следующего шага задания.

//CNDSAMP JOB CLASS=6,NOTIFY=&SYSUID
//*
//STP01 EXEC PGM=SORT
//* Assuming STP01 ends with RC0.

//STP02 EXEC PGM=MYCOBB,COND=(0,EQ,STP01)
//* In STP02, condition evaluates to TRUE and step bypassed.

//STP03 EXEC PGM=IEBGENER,COND=((10,LT,STP01),(10,GT,STP02))
//* In STP03, first condition fails and hence STP03 executes. 
//* Since STP02 is bypassed, the condition (10,GT,STP02) in 
//* STP03 is not tested.

COND = EVEN

Когда закодировано COND = EVEN, текущий шаг задания выполняется, даже если любой из предыдущих шагов завершился ненормально. Если любое другое условие RC закодировано вместе с COND = EVEN, то шаг задания выполняется, если ни одно из условий RC не является истинным.

//CNDSAMP JOB CLASS=6,NOTIFY=&SYSUID
//*
//STP01 EXEC PGM=SORT
//* Assuming STP01 ends with RC0.

//STP02 EXEC PGM=MYCOBB,COND=(0,EQ,STP01)
//* In STP02, condition evaluates to TRUE and step bypassed.

//STP03 EXEC PGM=IEBGENER,COND=((10,LT,STP01),EVEN)
//* In STP03, condition (10,LT,STP01) evaluates to true,
//* hence the step is bypassed.

COND = ТОЛЬКО

Когда закодировано COND = ONLY, текущий шаг задания выполняется только тогда, когда любой из предыдущих шагов завершается аварийно. Если любое другое условие RC закодировано вместе с COND = ONLY, то этап задания выполняется, если ни одно из условий RC не является истинным и любой из предыдущих этапов задания завершился аварийно.

//CNDSAMP JOB CLASS=6,NOTIFY=&SYSUID
//*
//STP01 EXEC PGM=SORT
//* Assuming STP01 ends with RC0.

//STP02 EXEC PGM=MYCOBB,COND=(4,EQ,STP01)
//* In STP02, condition evaluates to FALSE, step is executed 
//* and assume the step abends.

//STP03 EXEC PGM=IEBGENER,COND=((0,EQ,STP01),ONLY)
//* In STP03, though the STP02 abends, the condition 
//* (0,EQ,STP01) is met. Hence STP03 is bypassed.

IF-THEN-ELSE Construct

Другой подход к управлению обработкой заданий - использование конструкций IF-THEN-ELSE. Это дает большую гибкость и удобный способ условной обработки.

Синтаксис

Ниже приведен базовый синтаксис конструкции JCL IF-THEN-ELSE:

//name IF condition THEN
list of statements //* action to be taken when condition is true
//name ELSE 
list of statements //* action to be taken when condition is false
//name ENDIF

Ниже приводится описание используемых терминов в приведенной выше конструкции IF-THEN-ELSE:

  • name : Это необязательно, и имя может содержать от 1 до 8 буквенно-цифровых символов, начиная с алфавита, #, $ или @.

  • Condition : Условие будет иметь формат: KEYWORD OPERATOR VALUE, где KEYWORDSможет быть RC (код возврата), ABENDCC (код завершения системы или пользователя), ABEND, RUN (выполнение шага началось). AnOPERATOR может быть логическим оператором (И (&), ИЛИ (|)) или оператором отношения (<, <=,>,> =, <>).

пример

Ниже приводится простой пример, показывающий использование IF-THEN-ELSE:

//CNDSAMP JOB CLASS=6,NOTIFY=&SYSUID
//*
//PRC1   PROC
//PST1	   EXEC PGM=SORT
//PST2	   EXEC PGM=IEBGENER
//       PEND
//STP01  EXEC PGM=SORT 
//IF1    IF STP01.RC = 0 THEN
//STP02     EXEC PGM=MYCOBB1,PARM=123
//       ENDIF
//IF2    IF STP01.RUN THEN
//STP03a    EXEC PGM=IEBGENER
//STP03b    EXEC PGM=SORT
//       ENDIF
//IF3    IF STP03b.!ABEND THEN
//STP04     EXEC PGM=MYCOBB1,PARM=456
//       ELSE
//       ENDIF
//IF4    IF (STP01.RC = 0 & STP02.RC <= 4) THEN
//STP05     EXEC PROC=PRC1
//       ENDIF
//IF5    IF STP05.PRC1.PST1.ABEND THEN
//STP06     EXEC PGM=MYABD
//       ELSE
//STP07     EXEC PGM=SORT
//       ENDIF

Давайте попробуем разобраться в приведенной выше программе, чтобы разобраться в ней немного подробнее:

  • Код возврата STP01 проверяется в IF1. Если он равен 0, то выполняется STP02. В противном случае обработка переходит к следующему оператору IF (IF2).

  • В IF2, если STP01 начал выполнение, то выполняются STP03a и STP03b.

  • В IF3, если STP03b не ABEND, выполняется STP04. В ELSE нет никаких заявлений. Это называется оператором NULL ELSE.

  • В IF4, если STP01.RC = 0 и STP02.RC <= 4 истинны, то выполняется STP05.

  • В IF5, если шаг процесса PST1 в PROC PRC1 на шаге задания STP05 ABEND, то выполняется STP06. Иначе выполняется STP07.

  • Если IF4 принимает значение false, STP05 не выполняется. В этом случае IF5 не тестируется, и шаги STP06, STP07 не выполняются.

IF-THEN-ELSE не будет выполняться в случае аварийного завершения задания, такого как отмена пользователем задания, истечение времени задания или набор данных обратная ссылка на шаг, который был пропущен.

Установка контрольных точек

Вы можете установить набор данных контрольной точки внутри своей программы JCL, используя SYSCKEOV, что является заявлением DD.

А CHKPT- это параметр, закодированный для многотомных наборов данных QSAM в операторе DD. Когда CHKPT закодирован как CHKPT = EOV, контрольная точка записывается в набор данных, указанный в операторе SYSCKEOV в конце каждого тома многотомного набора данных ввода / вывода.

//CHKSAMP JOB CLASS=6,NOTIFY=&SYSUID
//*
//STP01     EXEC PGM=MYCOBB
//SYSCKEOV  DD DSNAME=SAMPLE.CHK,DISP=MOD
//IN1       DD DSN=SAMPLE.IN,DISP=SHR
//OUT1      DD DSN=SAMPLE.OUT,DISP=(,CATLG,CATLG)
//          CHKPT=EOV,LRECL=80,RECFM=FB

В приведенном выше примере контрольная точка записана в набор данных SAMPLE.CHK в конце каждого тома выходного набора данных SAMPLE.OUT.

Начать обработку заново

Вы можете перезапустить обработку эфира автоматизированным способом с помощью RD parameter или вручную с помощью RESTART parameter.

RD parameter кодируется в операторе JOB или EXEC и помогает в автоматическом перезапуске JOB / STEP и может содержать одно из четырех значений: R, RNC, NR или NC.

  • RD=R разрешает автоматический перезапуск и учитывает контрольную точку, закодированную в параметре CHKPT оператора DD.

  • RD=RNC разрешает автоматический перезапуск, но отменяет (игнорирует) параметр CHKPT.

  • RD=NRуказывает, что задание / шаг нельзя перезапустить автоматически. Но когда он перезапускается вручную с помощью параметра RESTART, параметр CHKPT (если есть) будет учитываться.

  • RD=NC запрещает автоматический перезапуск и обработку контрольных точек.

Если требуется выполнить автоматический перезапуск только для определенных кодов аварийного завершения, это можно указать в SCHEDxx член системной библиотеки IBM parmlib.

RESTART parameterзакодирован в операторе JOB или EXEC и помогает при ручном перезапуске JOB / STEP после сбоя задания. RESTART может сопровождаться идентификатором проверки, который представляет собой контрольную точку, записанную в наборе данных, закодированном в операторе SYSCKEOV DD. Когда кодируется checkid, оператор SYSCHK DD должен быть закодирован так, чтобы он ссылался на набор данных контрольной точки после оператора JOBLIB (если он есть), иначе после оператора JOB.

//CHKSAMP JOB CLASS=6,NOTIFY=&SYSUID,RESTART=(STP01,chk5)
//*
//SYSCHK    DD DSN=SAMPLE.CHK,DISP=OLD
//STP01     EXEC PGM=MYCOBB
//*SYSCKEOV	DD DSNAME=SAMPLE.CHK,DISP=MOD
//IN1       DD DSN=SAMPLE.IN,DISP=SHR
//OUT1      DD DSN=SAMPLE.OUT,DISP=(,CATLG,CATLG)
//          CHKPT=EOV,LRECL=80,RECFM=FB

В приведенном выше примере chk5 - это идентификатор проверки, т. Е. STP01 перезапускается в контрольной точке 5. Обратите внимание, что оператор SYSCHK добавлен, а оператор SYSCKEOV закомментирован в предыдущей программе, описанной в разделе «Установка контрольной точки».