ログファイルを読み取り、エラーレベルのログがあった場合はエラーメールを送信したい

キーワード:区切り文字,デリミタ文字,CSV
シナリオ一覧に戻る

概要

ログファイルなど、「,」(半角カンマ)以外で区切られたファイルを読み取りたい場合、CSVファイル読み取り処理を使用し、[デリミタ文字]を設定します。
ログファイルを分析し、エラーレベルのログが存在する場合は、ログファイルを添付ファイルとしてエラーメールを送信します。

サンプルプロジェクトの説明

「|」(半角バーティカルバー)で区切られたログファイルを読み取り、「ログレベル」を判定します。
エラーレベルのログが存在する場合、ログファイルを添付ファイルとしてメールを送信します。
本シナリオでは、「WARN」・「ERROR」・「FATAL」をエラーレベルとして扱います。

処理の流れ

サンプルプロジェクトの処理の流れは以下の通りです。
  1. CSVファイル読み取り処理」で入力ファイルを読み取ります。
  2. マッピング処理」でエラーレベルのログを抽出します。
  3. エラーレベルのログが存在する場合、「繰り返し(データ件数)処理」で以下の処理を行います。
  4. 1通メール送信処理」でログファイルを添付ファイルとしてエラーメールを送信します。
実行結果のイメージについては、以下を参照してください。

ポイントとなる機能

名前 説明 ツールパレット上の場所
マッピング処理 入力データの変換を行います。 「変換」-「基本」-「マッピング」
繰り返し(データ件数)処理 入力データの件数分、処理を繰り返します。 「基本」-「フロー」-「繰り返し(データ件数)」

処理のポイント

繰り返し(データ件数)処理は、データが1件以上ある場合に繰り返し処理を実行します。
なお、繰り返し処理は1回のみ実行したいため、break処理を使用して繰り返し処理を終了させます。

サンプルプロジェクトの使用方法

上記処理を実装したサンプルプロジェクトを用意しています。サンプルプロジェクトを使用する場合の手順は、以下の通りです。

サンプルプロジェクトファイル名 rl_reference_063.zip
  1. サンプルプロジェクトの展開
    サンプルプロジェクトファイル「rl_reference_063.zip」を展開します。

  2. プロジェクトのアップロード
    「rl_reference_063.zip」を展開後に作成される「rl_reference_063プロジェクト」ディレクトリがプロジェクトファイルとなります。
    DataSpider Studioを起動し、マイプロジェクトの画面から[ファイル]-[ローカルからアップロード]で展開したディレクトリ「rl_reference_063プロジェクト」をアップロードしてください。

  3. サンプルデータの準備
    「rl_reference_063.zip」を展開後に作成される「samples」ディレクトリがサンプルデータとなります。
    $DATASPIDER_HOME/server/samplesディレクトリに上書きしてください。

  4. コントロールパネルの[グローバルリソースの設定]から、[新しいグローバルリソースの追加]を選択し、メール送信サーバ接続設定のグローバルリソースを作成します。
    グローバルリソースの作成方法については、メールアダプタの「グローバルリソースのプロパティ」を参照してください。

スクリプトの作成手順

プロセスフローおよびデータフローは、「サンプルプロジェクトの説明」のスクリプト画像を参照して適宜設定してください。
  1. デザイナのツールパレット「ファイル」-「CSV」-「CSVファイル読み取り」から、CSVファイル読み取り処理をスクリプトキャンバスに配置します。

  2. デザイナのツールパレット「変換」-「基本」-「マッピング」から、マッピング処理をスクリプトキャンバスに配置します。

  3. デザイナのツールパレット「基本」-「フロー」-「繰り返し(データ件数)」から、繰り返し(データ件数)処理をスクリプトキャンバスに配置します。

  4. マッピング処理のMapperエディタを開き、エラーレベルのログを抽出する処理を作成します。

  5. デザイナのツールパレット「ネットワーク」-「メール」-「1通メール送信」から、1通メール送信処理をスクリプトキャンバスに配置します。

  6. デザイナのツールパレット「基本」-「フロー」-「break」から、break処理をスクリプトキャンバスに配置します。

  7. スクリプトを実行し、正常終了すれば成功です。