前回に引き続き、第3回 JCL1シナリオ を実施する。
このシナリオの学習目的は
・これまでJCLを扱ってきたがそれほど深く触れてきていなかった。この回でZ/OS環境下でなぜ重要なのかもう少し深く学習する。
・JCLはZ/OSの中核なので、課題を通してコンセプトと文法に慣れる。
1. 課題にアクセス
まず、Z xplore にアクセスし、「FUNDAMENTALS」をクリック
2. シナリオPDF入手
3つ目のシナリオである「JCL1」が選択可能となっているのでクリックし、PDFをダウンロードしておく。
3.シナリオ JCL1-1 LOAD IT UP
「JCLSETUP」ファイルを"ZXP.PUBLIC.JCL"から探しだす。
このファイルはこのシナリオで利用するデータを作るといった単純なジョブ。
ファイルを見てみると、「&SYSUID」というメンバーがある。"SYSUID"と共に記述されているアンパサンドはシンボルとして知られており、システムが"&SYSUID"を!ユーザIDと置き換えるようになっている。
4.シナリオ JCL1-2 SUBMIT IT
上記で検索した「JCLSETUP」を右クリックして「Submit job」を実行。
“Job”について:JCLはシステムに何をしたいのか記述しているものであり、システムに伝えられるタスクはジョブ。これらのジョブの結果にアクセスし、処理し、管理できるz/OSのコンポーネントはJES(Job Entry Subsystem)である。
このJCL1に関して、先ほど「Submit job」したようにタスクを処理するためシステムにJESを投じる。
5.シナリオ JCL1-3 FILTER AND FIND IT
この段階で、VSCodeの左下に"JOBS"があり、拡大鏡アイコンをクリックして以下のような検索を実施することが可能。
・ユーザーIDを入力してジョブオーナーの結果検索
・*(アスタリスク) を入力して接頭語検索
・ブランク検索でJobID検索
拡大鏡アイコンをクリックし、オーナーや接頭語を選ぶことで再建策可能。先ほどSubmitしたジョブも検索可能であり、次からそれを見ていく。
6.シナリオ JCL1-4 YOU GOT A ZERO.PERFECT!
VSCodeの左下にある"JOBS"の中で、先ほどSubmitした"JCLSETUP"の隣にある">"をクリック。他のジョブ結果もあるかもしれないが、ここではJCLSETUPに集中。一度Submitしていると、ジョブの右側に"CC 0000"がある。
また、JESMSGLGの中にも同様の数字を見つけれられる。CC (Condition Code) 0000 は全て期待通りのエラーなしを意味している。逆に、その他コード番号を得た場合は、調査し修正する箇所があることを示す。
7.シナリオ JCL1-5 JUMP RIGHT TO IT
JCL を Submit した後、小さなメッセージが VSCode の画面右下に現われることに気づくと思う。VSCodeの左下にある"JOBS"を見ていくよりも、このメッセージをクリックする方がより早く結果にアクセスすることが可能。
ジョブは開始直後の "ACTIVE" から開始し、ジョブの">"を再表示することでステータスを更新できる。
8.シナリオ JCL1-6 KICKING OFF SOME COBOL
ZXP.PUBLIC.JCL から JCL2 を自身の Zxxxxx.JCL データセットへコピーし、">"マークをクリックすることによりJCL データセットを再表示する。このJCLは COBOL コードをコンパイル、実行するために使われる。すなわち、コンパイルした後、このコードは LOAD data set 内に結果プログラムを出力する。
JCL の中で、データがどこから来て、どこへ行くのか記載しているステートメントは Data Definition Statement、または単に DD ステートメントと言われる。
JCL2 のファイルを見ると、18行目にインプットのデータセットが示されていて、19行目にアウトプットを出力することがわかる。
※ダウンロードしたドキュメントに記載された記述と、手元で実施しているファイルに差異があるので、ここでは実際に操作した内容に基づいて記載する。
さらにコードを見ていくと、リターンコード0(エラーなく、全て正常終了)の場合
プログラムを実行する。
これまでのところをおさらいすると、コードをコンパイルし実行するためにJCLを使う。
9.シナリオ JCL1-7 RUN, CODE, RUN
COBOL コードをコンパイルした後、23行目を実行する。その際、インプットデータを25,26行目から得て、アプトを27行目で定義する。
例えば、DDステートメントの名前は"//"後の"FNAMES","LNAMES"である。
"//*"で始まる行はコメントであり、JESから無視される。が、コメント行はあとでコードを理解する情報を提供してくれる。
10. シナリオJCL1-8 THEY CAN'T ALL BE ZEROS
Zxxxxxx データセット内の JCL2 をサブミットし、7で示したように実行結果を見ると、ABEND(異常終了の短縮型)と示されているように上手くいっていない。
でも、大丈夫。
次のステップで、COBOLコードを見て、実際のCOBOL
COBOLコードとコンパイルするJCLコードをどのように比較するか理解する。
11.シナリオJCL1-9 COMPARE THE CODE
"//COBOL.SYSIN"で始まる行がコンパイル対象のCOBOLコードを示している。そこで、
そのコード(CBL001)を開いてみる。この CBL001 は"ZXP.PUBLIC.SOURCE" に存在している。
CBL001 を開き、"FILE-CONTROL"を探す。
ここには、JCL の中で参照する変数名を示している。例えば、COBOLコードの中でFIRST-NAME が JCL コード内の DD ステートメントで FNAMES に割り当てられている。
この2つのコードを並べて開き、変更すべき箇所を確認する。
※変更すべき箇所は、JCL2 の 27行目。CBL001 では、"COMBINED"と定義されているのに JCL2 では"COMBINE"となっている。そこで、JCL2にある"COMBINE"を"COMBINED"に修正。
その後、JCL2 を Submit すると、CC=0 が得られ正常終了を確かめられる。
12.シナリオJCL1-10 ALL ABOARD
ZXP.PUBLIC.JCL から JCL3 を自身の Zxxxxx.JCL データセットへコピーし、">"マークをクリックすることによりJCL データセットを再表示する。すると、この JCL コードには、シーケンシャルデータセットへ入力を指示する IEBGENER を持つコードもあることが分かる。
ヘッダーから、ニューヨークのポキプシー駅とグランドセントラル駅の間の情報であり、テキストで運行時間が記載されている。
13.シナリオJCL1-11 YOU'RE NO DUMMY
JCL3 の中の"DUMMY"については、気にする必要がない。この JCL は何もコールしていない、ただ「パラメータは必要とされるが、何もしないので問題ない」とのこと。
14.シナリオJCL1-12 A FRIENDLY DISPOSITION
ここまでの JCL の中で、DISP(disposition)パラメータを見てきた。DISP パラメータとは、システムに対してデータ・セットの状況を説明し、そ のステップまたはジョブの終了後のデータ・セットの後処理方法を指定する ために使用する。
標準DISPパラメータは3パーツで構成されている。第一フィールドが状態であり、次の文字列が使われる。
NEW : データセット新規作成
SHR : 既存データの再利用、他のユーザに必要であれば利用させる
OLD : 既存データの再利用、他のユーザに必要であれば利用させない
MOD : シーケンシャルなデータセットだけ。既存データを利用するが、新規レコードのみ。データセットがなければ、新規作成。
15.シナリオJCL1-13 WHAT'S YOUR STATUS
DISPパラメータの次の第2フィールドでは、正常完了時にデータセットに何が起こるのか示している。また、第3フィールドで異常発生時にデータセットに何が起こるのか示している。
JCL3では様々な値が使われているが、まずは以下の3つを知っておくべき
DELETE : ストレージから完全消去
CATLG : 後で利用するため記録
PASS : このステップ完了後に利用するため保持
16.シナリオJCL1-14 RIGHT ON TIME
JCL3を Submit し結果を見ると、100%正しく完了するために2か所の編集が必要ということが分かる。
重複停車は不要。つまり、2度表示されている"Beacon"と"Cortiant"の重複を削除する。
そこで、JCL3 を修正。
まず、"Beacon"
次いで、"Cortiant"
その後、Zxxxxx.JCL3OUT データセットを削除し、再度 Submit 実施。
※Zxxxxx.JCL3OUT データセットを削除しなければ、以下のエラーとなる。
17.WHO KNEW?
最後に JCL2 と JCL3 の結果を評価するため、ZXP.PUBLIC.JCL 内の CHKJCL1 を Submit し、正常終了( CC=0 )することを確認する。
CHKJCL のリターンコードが CC=0127であれば、「11 シナリオJCL1-9 COMPARE THE CODE」とJCL3を確認すること。
18. 締め
JCL1挑戦画面( https://ibmzxplore.influitive.com/ )を見てみると、「Challenge Complete, check my FILES submission」ボタンが表示されているので、こちらをクリックして完了!