実施環境:
[root@testhost ~]# uname -a
Linux testhost 4.18.0-338.el8.x86_64 #1 SMP Fri Aug 27 17:32:14 UTC 2021 x86_64 x86_64 x86_64 GNU/Linux
[root@testhost ~]# cat /etc/redhat-release
CentOS Stream release 8
[root@testhost ~]# yum list installed | grep hinemos
hinemos-7.0-agent.noarch 7.0.1-1.el @@commandline
hinemos-7.0-manager.x86_64 7.0.1-1.el8 @@commandline
hinemos-7.0-web.x86_64 7.0.1-1.el8 @@commandline
0. 概要
業務というものは、大抵の場合複数の処理に分解することができます。
例えば「ある通販サイトの商品の売れ行きの集計をメールで受け取る」という業務があった場合、「データの集計」「 PDF ファイルに変換」「メールで送信」のような処理に分けられたりするかもしれません。
このような業務をプログラム化する際、大抵は、すべての処理を1つのプログラムに入れたりせず、処理単位で別々のプログラムを作成し、それらを順番に実行するという形になります。
簡単な業務であれば手動でこれらを行う場合もあるでしょうが、処理の結果によって次の処理を変えるような複雑な業務や、何百、何千もの処理からなる巨大な業務、毎日決まった時間に行うような定期的な業務となると、手動で行うのは大変ですし、なによりミスのもとです。
このような場面で利用されるのが「ジョブ管理システム」です。
「ジョブ」はユーザがコンピュータに依頼する仕事の単位で、1つまたは複数のプログラムからなります。
このジョブを制御するのがジョブ管理システムで、ジョブを一定間隔で起動したり、ジョブの動作状況を監視したりすることができます。
「 Hinemos 」はこのジョブ管理システムとしての機能を持つソフトウェアの1つです。
今回はこの Hinemos における、ジョブの基本的な作り方を紹介します。
なお、今回、 Hinemos 自体のインストールやマネージャとエージェントの紐づけなどは既に済んでいるものとして扱います。
その部分について知りたい場合は、以下の過去記事をご参照ください。
1. ジョブの作成
まずは、簡単なジョブを1つ作ってみましょう。
1.1. ジョブユニットの作成
ジョブの編集は「パースペクティブ」⇒「ジョブ設定」から行います。
さて、Hinemos のジョブは階層構造の上位から、「ジョブユニット」「ジョブネット」「ジョブ」の3層構造となっています。
簡単に言うと、ジョブユニットはジョブをまとめるフォルダのようなもので、ジョブが個々の処理、複数のジョブを1つのセットにしたものがジョブネットとなります。
まずは最上位のジョブユニットを作成しましょう。
「マネージャ(マネージャ1)」を選択し、「ジョブユニットの作成」ボタンを押します。
今回は、ジョブ ID に「 job_unit_01
」、ジョブ名に「 ジョブユニット_01 」とします。
それ以外の設定はすべてデフォルトでよいです。
入力したら「 OK 」を押します。
これでジョブユニットが作成されます。
1.2. ジョブネットの作成
作成されたジョブユニットは、編集モードになっています。
「ジョブネットの作成」ボタンを押してジョブネットを作成しましょう。
今回はジョブネットのジョブ ID は「 jobnet_01_01
」、ジョブ名は「 ジョブネット_01_01 」にしましょう。
それ以外の設定はすべてデフォルトで「 OK 」を押します。
これでジョブネットも作成できました。
1.3. ジョブの作成
最後に、「コマンドジョブの作成」ボタンを押してジョブを作成します。
今回、ジョブ ID は「 job_01_01_01
」、ジョブ名は「 ジョブ_01_01_01 」にしました。
さらに「コマンド」タブを選択し、起動コマンドに以下のコマンドラインを指定します。
date >> /tmp/test_01.log
次にコマンドを実行するサーバを指定するため、スコープで「固定値」を選択して、その右の「参照」ボタンを押します。
登録してあるスコープを選択して、「 OK 」を押します。
他の項目はデフォルトのままでよいですので、「 OK 」を押します。
これで、ジョブも作成できました。
1.4. 編集モードの終了
これで設定は以上ですので、「登録」ボタンを押します。
ボタンを押すことで、ここまでの変更が確定します。
確認メッセージが出るので、「 Yes 」を押します。
以下のようなメッセージが表示されれば成功です。
「編集モード」の文言が消えているのがわかると思います。
2. ジョブの実行
作成したジョブを、実行してみましょう。
2.1. ジョブの実行
ジョブを手動で実行するには、「実行」ボタンを押します。
確認メッセージが出るので、「実行」を押します。
これで、ジョブが実行できました。
なお、上の例ではジョブを単体で実行しておりますが、ジョブの構成によっては上位のジョブネットを選択して実行しなくてはならない場合もあります。
2.2. ジョブの実行結果
ジョブの実行結果は、ジョブの編集画面とは別の画面から確認します。
「パースペクティブ」⇒「ジョブ履歴」を選択してください。
すると、ジョブの履歴画面が表示されます。
正しく設定が行われていれば、先ほど手動で実行したジョブについて、「実行状態」が「終了」、終了状態が「正常」になっているはずです。
OS 側から見ても、きちんと動作できていることがわかります。
[root@testhost ~]# ls -l /tmp/test_01.log
-rw-r--r-- 1 root root 43 2月 4 13:22 /tmp/test_01.log
[root@testhost ~]# cat /tmp/test_01.log
2024年 2月 4日 日曜日 13:22:45 JST
[root@testhost ~]#
3. 順序性を持ったジョブ
次に、ジョブをもう1つ作って、先ほど作ったジョブの後に実行されるようにしてみましょう。
3.1. 2番目に起動するジョブの作成
まずは、先ほど作成したジョブユニットを選択して、「編集モード」を押します。
ジョブネットを選択して、「コマンドジョブの作成」ボタンを押します。
ジョブ ID は「 job_01_01_02
」、ジョブ名は「 ジョブ_01_01_02 」にし、起動コマンドには以下のコマンドラインを指定します。
それ以外は先ほどのジョブと同じ設定でよいです。
設定できたら「 OK 」を押します。
mv /tmp/test_01.log /tmp/test_02.log
さて、ジョブの順序性ですが、「待ち条件」タブから編集します。
ここで例えば「あるジョブが正常終了」「特定の時刻に到達」などの条件を組み合わせて、ジョブが起動するための条件を作成します。
まずは「追加」を押して条件を1つ追加しましょう。
条件の編集画面は以下のようになっています。
「追加」を押して、新しいルールを1つ追加します。
新しいルールが1つ追加されました。
ここからこのルールを編集していきます。
ルールの種類について、今回は 1 で作ったジョブ「 ジョブ_01_01_01 」の後にこのジョブ「 ジョブ_01_01_02 」を動かしたいので、「ジョブ(終了状態)」を選択します。
これを開くと、以下のように編集できる項目が表示されます。
まずは、ジョブ ID に 1 で作ったジョブ「 ジョブ_01_01_01 」を指定します。
次に、値に「正常」を指定します。
最後に「 OK 」を押して、設定を終了します。
これで、 1 で作ったジョブ「 ジョブ_01_01_01 」が正常に完了した場合に、今回作ったジョブ「 ジョブ_01_01_02 」が起動するように設定できました。
3.2. 実行確認
実際にジョブを動かして確認してみましょう。
なお、今回は下位のジョブではなく、上位のジョブネット「 ジョブネットテスト_01_01 」から実行します。
下位のジョブ「 ジョブ_01_01_01 」や「 ジョブ_01_01_02 」から起動しても、各ジョブが単体で実行されるだけで順序性の確認はできないので注意してください。
ジョブが順番に動作しました。
OS 側から見ても、きちんと順番に動作できていることがわかります。
[root@testhost ~]# ls -l /tmp/test_*
-rw-r--r-- 1 root root 86 2月 4 13:35 /tmp/test_02.log
[root@testhost ~]# cat /tmp/test_02.log
2024年 2月 4日 日曜日 13:22:45 JST
2024年 2月 4日 日曜日 13:35:43 JST
[root@testhost ~]#
4. 定期的に起動するジョブ
ここまでジョブを手動で起動してきましたが、実際のところジョブは、毎日何時や毎時何分など、定期的に起動させたいことの方が多いです。
今回は先ほど作ったジョブについて、毎時 00 分で起動するようにしてみましょう。
4.1. スケジュールの作成
スケジュールはジョブの設定として作成するのではなく、ジョブとは別の「スケジュール」として作成し、それをジョブに適用するという形をとります。
そのため設定場所も「ジョブ設定[一覧]」ではなく、その下の「ジョブ設定[実行契機]」となります。
「スケジュール作成」を押し、新しいスケジュールを作成します。
まずはスケジュール名を決めましょう。
今回は「実行契機 ID 」に「 schedule_01
」、「実行契機名」に「 スケジュール_01 」と入力します。
次にジョブについて、先ほど作ったジョブ「 ジョブネット_01_01 」を指定します。
そしていよいよスケジュール設定です。
「スケジュール設定」タブから設定します。
今回は毎時 00 分に起動させたいので、「毎時」「 00 分から」「 60 分ごと」に設定します。
「登録」ボタンを押して登録します。
「登録成功」と出れば OK です。
4.2. 実行確認
実際に 00 分まで待って、ジョブが実行されるのを確認してみます。
00 分にジョブが実行されました。
OS 側から見ても、きちんとスケジュール通りに実行されていることがわかります。
[root@testhost ~]# ls -l /tmp/test_*
-rw-r--r-- 1 root root 43 2月 4 14:00 /tmp/test_02.log
[root@testhost ~]# cat /tmp/test_02.log
2024年 2月 4日 日曜日 14:00:01 JST
[root@testhost ~]#
5. インポート・エクスポートに関する注意点
Hinemos のジョブは、「インポート」「エクスポート」ボタンを押すことでインポート、エクスポートできます。
ただし、この機能が利用できるのはエンタープライズ版のみです。
OSS 版では利用できないので注意してください。