× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.


  • Subject: RE: Alert job owner of QSYSOPR message?
  • From: Rob Berendt <rob@xxxxxxxxx>
  • Date: Tue, 30 Jun 1998 13:11:00 -0500

I have another job that monitors subsystem QBATCH on a routine basis and
every 15 minutes it sends a message out to a select group of people for
each job that is stuck.  You could probably modify this to suit your needs.
 There is some other stuff in there about certain jobs not running that
should be that you could trash if you want to.
/***************************************************************************
***/
/*                                                                   */
/*    Program:      GDIQBATCHM                                       */
/*    Description:  Check Active Jobs in Subsystems                  */
/*    Written by:   Douglas W. Turnpaugh of GDS, LLC.                */
/*    Date:         October 20, 1994                                 */
/*                                                                   */
/* Modification log:                                                 */
/* 11/10/94 by R.Berendt, CDP  -  GDS, LLC                           */
/*          Changed length of message text from 30 to 80.            */
/* 11/11/94 by R.Berendt, CDP  -  GDS, LLC                           */
/*          Copied program AUD005C from EDIPGM over to GDIQBATCHM    */
/*          in ROUTINES.  Changed it to stop ensuring that certain   */
/*          jobs were running.  Now it will only see if any jobs in  */
/*          QBATCH are in a MSGW state.                              */
/*          Added parameter of Delay time so this will become a      */
/*          never ending job.                                        */
/*          Ignore QSCHRMT - Search Remote Calendars                 */
/* 03/11/96 by R.Berendt, CDP  -  GDS, LLC                           */
/*          Changed size of receiver variable from X'00000076' to    */
/*          X'0000006F' to prevent program from blowing up on V3R6.  */
/*          We were suprized that it wasn't blowing up on previous   */
/*          versions.                                                */
/*                                                                   */
/* Required objects:                                                 */
/* QBATCHMSG   *FILE    message group                                */
/* SNDMSGGRP   *CMD     ROUTINES-(and all objects required by it)    */
/* GDIQBATCHM  *JOBD    Can be added to subsystem QBATCH as an       */
/*                      autostart job.                               */
/* GDIQBATCHM  *CMD     A nice way to start this program.            */
/*                                                                   */
/***************************************************************************
***/
BATCHK:     PGM        PARM(&DLYTIME)

/*  VARIABLES USED FOR THE FORMAT                                   */

             DCL        VAR(&BIN4)    TYPE(*CHAR) LEN(4)
                          /* Number of jobs for list job and User +
                             space offset in binary 4 form */
             DCL        VAR(&DEC8)    TYPE(*DEC)  LEN(8 0)
                          /* User space offset in decimal 8,0 form */
             DCL        VAR(&ELEN)    TYPE(*DEC)  LEN(8 0)
                          /* List job entry length in decimal 8,0 +
                             form */
             DCL        VAR(&ELENB)   TYPE(*CHAR) LEN(4)
                          /* List job entry length in binary 4 form */
             DCL        VAR(&EUSRSPC) TYPE(*CHAR) LEN(10)
                         /* User space name for command    */
             DCL        VAR(&FORMAT)  TYPE(*CHAR) LEN(8) +
                          VALUE('JOBI0200')
                          /* Format Name */
             DCL        VAR(&INTJOB) TYPE(*CHAR) LEN(16)
                          /* Internal Job Identifier */

/*  Indicator Variables for Checking Active Programs                */
/*  Will be set to Yes if found in the active job list              */

             DCL        VAR(&JN1) TYPE(*CHAR) LEN(1) VALUE('N')
             DCL        VAR(&JN2) TYPE(*CHAR) LEN(1) VALUE('N')
             DCL        VAR(&JN3) TYPE(*CHAR) LEN(1) VALUE('N')
             DCL        VAR(&JN4) TYPE(*CHAR) LEN(1) VALUE('N')
             DCL        VAR(&JN5) TYPE(*CHAR) LEN(1) VALUE('N')
             DCL        VAR(&JN6) TYPE(*CHAR) LEN(1) VALUE('N')

             DCL        VAR(&JOB)     TYPE(*CHAR) LEN(10) +
                          VALUE('*ALL      ') /* Job Name */
             DCL        VAR(&JOBI)    TYPE(*CHAR) LEN(111)
                          /* Retrieval area for Job Information */
             DCL        VAR(&JOBNAME) TYPE(*CHAR) LEN(26)
                          /* Job Name - for this job */
             DCL        VAR(&LJOBE)   TYPE(*CHAR) LEN(56)
                          /* Retrieve area fof internal job id */
             DCL        VAR(&LOOP)    TYPE(*DEC)  LEN(8 0)
                          /* Number of jobs from list job */
             DCL        VAR(&MSG)     TYPE(*CHAR) LEN(80)
             DCL        VAR(&NUMBER)  TYPE(*CHAR) LEN(6)
                         /* Current Job Number */
             DCL        VAR(&RJOB)     TYPE(*CHAR) LEN(10) +
                           /* Job Name from Job list */
             DCL        VAR(&RUSER)    TYPE(*CHAR) LEN(10) +
                           /* User Name from Job list */
             DCL        VAR(&STAT)    TYPE(*CHAR) LEN(4)
                          /*  Active Job Status */
             DCL        VAR(&SUBDESC) TYPE(*CHAR) LEN(10)
                          /* Subsystem Description Name */
             DCL        VAR(&USER)    TYPE(*CHAR) LEN(10) +
                          VALUE('*ALL      ') /* User Name */
             DCL        VAR(&USRSPC) TYPE(*CHAR) LEN(20) +
                          VALUE('CHGA      QTEMP     ') /* User +
                          Space Name for API's */

             DCL        VAR(&DLYTIME) TYPE(*DEC) LEN(4 0) /* Number +
                          of seconds to delay job. */

/*  Retrieve Job Number                                              */

             RTVJOBA    NBR(&NUMBER)

/*  Incorporate Job number into the User Space name                  */

             CHGVAR     VAR(%SST(&USRSPC 5 6)) VALUE(&NUMBER)
             CHGVAR     VAR(&EUSRSPC) VALUE(%SST(&USRSPC 1 10))

/*  Delete User Space if it already exists                           */

             DLTUSRSPC  USRSPC(QTEMP/&EUSRSPC)
             MONMSG     MSGID(CPF0000)

MAJORLOOP:  /* ROB 11/11/94 */

/*  Create User Space                                                */

             CALL       PGM(QUSCRTUS) PARM(&USRSPC 'WRKACTJOB ' +
                          X'00000100' ' ' '*ALL      ' 'WORK ACTIVE +
                          JOB - TEMPORARY USER SPACE            ')

/*  Set Up Jobname                                                  */

             CHGVAR     VAR(%SST(&JOBNAME 1 10))  VALUE(&JOB)
             CHGVAR     VAR(%SST(&JOBNAME 11 10)) VALUE(&USER)
             CHGVAR     VAR(%SST(&JOBNAME 21 6))  VALUE('*ALL  ')

/*  List Active Jobs                                                 */

             CALL       PGM(QUSLJOB) PARM(&USRSPC 'JOBL0100' +
                          &JOBNAME '*ACTIVE   ')

/*  Retrieve the number of entries returned and convert to decimal.  */

             CALL       PGM(QUSRTVUS) PARM(&USRSPC X'00000085' +
                          X'00000004' &BIN4)
             CHGVAR     VAR(&LOOP) VALUE(%BINARY(&BIN4))

/*  If number of entries is zero to to NOJOBS label                  */

             IF         COND(&LOOP = 0) THEN(GOTO CMDLBL(FINISH))

/*  Retrieve List Entry length, convert to decimal.                  */
/*  Retrieve List Entry Offset, Convert to Decimal, and Add one      */
/*  to set the position.                                             */

             CALL       PGM(QUSRTVUS) PARM(&USRSPC X'00000089' +
                          X'00000004' &ELENB)
             CHGVAR     VAR(&ELEN) VALUE(%BINARY(&ELENB))

             CALL       PGM(QUSRTVUS) PARM(&USRSPC X'0000007D' +
                          X'00000004' &BIN4)
             CHGVAR     VAR(&DEC8) VALUE(%BINARY(&BIN4))
             CHGVAR     VAR(&DEC8) VALUE(&DEC8 + 1)

/*  Loop for the Number of Jobs until No more jobs then go to       */
/*  ALLDONE Label.                                                  */

STARTLOOP:  IF         COND(&LOOP = 0) THEN(GOTO CMDLBL(ALLDONE))

/*  Convert Decimal position to Binary 4 and retrieve List Job Entry.*/

             CHGVAR     VAR(%BINARY(&BIN4)) VALUE(&DEC8)
             CALL       PGM(QUSRTVUS) PARM(&USRSPC &BIN4 &ELENB &LJOBE)

/*  Copy internal job identifier and retrieve job information for   */
/*  basic performance information.                                  */

             CHGVAR     VAR(&INTJOB) VALUE(%SST(&LJOBE 27 16))
             CALL       PGM(QUSRJOBI) PARM(&JOBI X'0000006F' &FORMAT +
                          '*INT                      ' &INTJOB)

             MONMSG     MSGID(CPF3C51 CPF3C52 CPF3C54 CPF3C55) +
                          EXEC(GOTO CMDLBL(ENDLOOP))

/*  Copy Subsystem Name.                                             */

             CHGVAR     VAR(&SUBDESC) VALUE(%SST(&JOBI 63 10))

/*  If the Job is from Subsystem QBATCH then check for CNT300C,      */
/*  FAXCOMM, FAXSPOOL, GDISPL2, RXM, and RXROUTER for activity,      */

             IF         COND(&SUBDESC = 'QBATCH    ') THEN(DO)

/*  Copy Job Name.                                                   */

             CHGVAR     VAR(&RJOB)  VALUE(%SST(&JOBI 9 10))
             CHGVAR     VAR(&RUSER) VALUE(%SST(&JOBI 19 10))

/* Skip checking for certain active jobs - ROB 11/11/94 */
             GOTO       CMDLBL(NOSPEC1)

             IF         COND(&RJOB = 'CNT300C') THEN(CHGVAR +
                          VAR(&JN1) VALUE('Y'))

             IF         COND(&RJOB = 'FAXCOMM') THEN(CHGVAR +
                          VAR(&JN2) VALUE('Y'))

             IF         COND(&RJOB = 'FAXSPOOL') THEN(CHGVAR +
                          VAR(&JN3) VALUE('Y'))

             IF         COND(&RJOB = 'GDISPL2') THEN(CHGVAR +
                          VAR(&JN4) VALUE('Y'))

             IF         COND(&RJOB = 'RXM') THEN(CHGVAR +
                          VAR(&JN5) VALUE('Y'))

             IF         COND(&RJOB = 'RXROUTER') THEN(CHGVAR +
                          VAR(&JN6) VALUE('Y'))

NOSPEC1:  /* ROB 11/11/94 */

/* Ignore Search remote calendars job */
             IF         COND(&RJOB = 'QSCHRMT') THEN(DO)
/*  Copy Job Status                                                  */

             CHGVAR     VAR(&STAT) VALUE(%SST(&JOBI 108 4))

             IF         COND(&STAT = 'MSGW') THEN(DO)
             CHGVAR     VAR(&MSG) VALUE('Job' *BCAT &RJOB *TCAT ', +
                          User' *BCAT &RUSER *TCAT ' has a status +
                          of MSGW waiting in subsystem QBATCH')
             SNDMSGGRP    GROUP(QBATCHMSG) MSGTXT(&MSG)
             ENDDO      /* MSGW */
             ENDDO      /* QSCHRMT */

             ENDDO      /* Subsystem = QBATCH */

/*  At End of Loop set new decimal position to next entry and       */
/*  decrement loop counter by one.                                  */

ENDLOOP:    CHGVAR     VAR(&DEC8) VALUE(&DEC8 + &ELEN)
             CHGVAR     VAR(&LOOP) VALUE(&LOOP -1)
             GOTO       CMDLBL(STARTLOOP)

/*  Send Message to Group QBATCHMSG if any of the Jobs have a value of   */
/*  Y.                                                               */


ALLDONE:
/* Skip checking for certain active jobs - ROB 11/11/94 */
             GOTO       CMDLBL(NOSPEC2)

             IF         COND(&JN1 = 'N') THEN(SNDMSGGRP GROUP(QBATCHMSG) +
                          MSGTXT('CNT300C is not running in QBATCH'))

             IF         COND(&JN2 = 'N') THEN(SNDMSGGRP GROUP(QBATCHMSG) +
                          MSGTXT('FAXCOMM is not running in QBATCH'))

             IF         COND(&JN3 = 'N') THEN(SNDMSGGRP GROUP(QBATCHMSG) +
                          MSGTXT('FAXSPOOL is not running in QBATCH'))

             IF         COND(&JN4 = 'N') THEN(SNDMSGGRP GROUP(QBATCHMSG) +
                          MSGTXT('GDISPL2 is not running in QBATCH'))

             IF         COND(&JN5 = 'N') THEN(SNDMSGGRP GROUP(QBATCHMSG) +
                          MSGTXT('RXM is not running in QBATCH'))

             IF         COND(&JN6 = 'N') THEN(SNDMSGGRP GROUP(QBATCHMSG) +
                          MSGTXT('RXROUTER is not running in QBATCH'))

NOSPEC2:  /* ROB 11/11/94 */

/*  Delete User Space */

FINISH:      DLTUSRSPC  USRSPC(QTEMP/&EUSRSPC)
             MONMSG     MSGID(CPF0000)

/* ROB 11/11/94 */
             DLYJOB     DLY(&DLYTIME)
             GOTO       CMDLBL(MAJORLOOP)

             ENDPGM

As an Amazon Associate we earn from qualifying purchases.

This thread ...


Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.