Wednesday, January 19, 2022

When was the last IPL performed?

when last ipl

One of the IBM i operators and I were talking about the contents on one of the little use Power server partitions and the following question came up: When was the last time an IPL was performed on this partition?

I know I could find that information in Service Tools. But how would I do so if I am not authorized to use the Service Tools menu?

Fortunately SQL comes to my rescue.

When an IPL starts a job with the following job number is always the first to start: 000000/QSYS/SCPF

I can use the JOBLOG_INFO to get the first entry from the job log for that job:

01  SELECT MESSAGE_TIMESTAMP
02  FROM TABLE(QSYS2.JOBLOG_INFO('000000/QSYS/SCPF'))
03  LIMIT 1

Line 1: This is the only column I need in my results.

Line 2: I pass the table function the job name of the first job on the system.

Line 3: I only want the first row from the results as that will be first message executed on the IPL-ing system.

My results are:

MESSAGE_TIMESTAMP
--------------------------
2021-12-16 12:20:48.734963

What if I wanted to know what kind of IPL was being performed?

There are four kinds of IPLs that I can track:

  1. Attended IPL
  2. Attended IPL after abnormal system ending
  3. Unattended IPL
  4. Unattended IPL in progress after abnormal system end

Fortunately there are message ids for those types of IPLs, and I can find them using the MESSAGE_FILE_DATA SQL view.

I first searched for any message that contained "IPL" in the message text column, and from those results I found the four message ids I need:

01  SELECT MESSAGE_ID,MESSAGE_TEXT
02    FROM QSYS2.MESSAGE_FILE_DATA
03   WHERE MESSAGE_FILE_LIBRARY = 'QSYS'
04     AND MESSAGE_FILE = 'QCPFMSG'
05     AND MESSAGE_ID IN ('CPF0903','CPF0905','CPF0997','CPF0998')

Line 1: These are the only two columns I need in my results.

Lines 3 and 4: The messages I am after are in IBM's message file QCPFMSG, which is found in the library QSYS.

Line 5: These are the messages I identified earlier.

My results are:

MESSAGE_ID  MESSAGE_TEXT
----------  -----------------------------------------------------
CPF0903     Unattended IPL in progress.
CPF0905     Attended IPL in progress.
CPF0997     Attended IPL after abnormal system ending.
CPF0998     Unattended IPL in progress after abnormal system end.

IBM does have a set of instructions on how to find this information on your partition, the link is at the bottom of this post. I have taken their instructions, and "modernizing" it to use SQL to find the data we want rather than have to scroll through pages of the system history log.

First step is to call the program QWCCRTEC:

CALL QSYS/QWCCRTEC

In my experience you will need call this with a profile that has at least *SECADM authority.

The program generates a spool file, QPSRVDMP. I open the spool file and scan for the string "PWRDWN", like the last line shown below.


5770SS1 V7R4M0  190621              DUMP

OBJECT TYPE-           SPACE                                           *QTSP
NAME-        QWCSRCDATAOUTPUT                TYPE-          19   SUBTYPE-          EF
CREATION-    01/05/22  07:50:05              SIZE-          0000006000
ATTRIBUTES-          0000                    ADDRESS-       F8F6B58255 000000
SPACE ATTRIBUTES-
 000000  00FFF000 00000074 D6E4E3D7 E4E34040 40404040  *  0    È ÕQWCSRCDATAOUTPUT      *
 000020  40404040 40404040 00100000 00000000 00000000  *                  &             *
 000040  00000000 00000000 00000000 00000000 00000000  *                                *
 000060  00000000 00000000                             *                  0             *
SPACE-
 000000  E7D7C640 D7E6D9C4 61F2F140 F1F27AF1 F87AF1F9  *XPF PWRDWN     12/16/21 12:18:19*

I record the date, 12/16/21, and the time, 12:18:19, as I will need this in the next step. This is not the time and date the IPL started, but the time and date of the power down before the IPL started.

Rather than scrolling through the history log I am going to use one of my favorite SQL table functions HISTORY_LOG_INFO. This table function allows me to search the history log for a range of timestamps.

01  SELECT MESSAGE_TIMESTAMP,MESSAGE_ID,FROM_JOB,MESSAGE_TEXT
02    FROM TABLE(QSYS2.HISTORY_LOG_INFO('2021-12-16-12.17.00.000000',
03                                      '2021-12-16-12.30.00.000000'))
04   WHERE MESSAGE_ID IN ('CPF0903','CPF0905','CPF0997','CPF0998')

Line 1: I am only interested in these columns for my results.

Lines 2 and 3: I need to pass HISTORY_LOG_INFO a start and end time stamp for the results. In this case my start time is a second before the time I recorded from the spool file. The end time is just 10 minutes after the time. This range will ensure I capture the information I want.

Line 4: The list of message ids for the types of IPL.

MESSAGE_TIMESTAMP           MESSAGE_ID  FROM_JOB          MESSAGE_TEXT
--------------------------  ----------  ----------------  ---------------------------
2021-12-16 12:20:48.734963  CPF0903     000000/QSYS/SCPF  Unattended IPL in progress.

The results show the same timestamp as I received when I use the JOBLOG_INFO table function. But here I know that this IPL was an unattended one.

 

You can learn more about this from the IBM website:

 

This article was written for IBM i 7.4, and should work for some earlier releases too.

1 comment:

  1. This is very handy. I always do a WRKACTJOB SBS(QCTL) then option 5 on the subsystem and then option 1 to see when the QCTL subsystem job started. The SQL statement is much easier.

    ReplyDelete

To prevent "comment spam" all comments are moderated.
Learn about this website's comments policy here.

Some people have reported that they cannot post a comment using certain computers and browsers. If this is you feel free to use the Contact Form to send me the comment and I will post it for you, please include the title of the post so I know which one to post the comment to.