ログファイルを表示する - Amazon EMR

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

ログファイルを表示する

Amazon EMR と Hadoop はいずれも、クラスターの状態を報告するログファイルを生成します。デフォルトで、ログファイルは /mnt/var/log/ ディレクトリのマスターノードに出力されます。クラスターの起動時に設定した方法に応じて、ログは Amazon S3 にアーカイブされる場合や、グラフィカルなデバッグツールを使用して表示できる場合があります。

さまざまな種類のログがマスターノードに出力されます。Amazon EMR は、ステップ、ブートストラップアクション、およびインスタンスの状態ログを出力します。Apache Hadoop は、ジョブ、タスク、およびタスク試行の処理を報告するログを出力します。また、Hadoop は、デーモンのログも記録します。Hadoop から出力される情報の詳細については、http://hadoop.apache.org/docs/stable/hadoop-project-dist/hadoop-common/ClusterSetup.html を参照してください。

マスターノードでのログファイルの表示

次の表は、マスターノードに保存されるログファイルの一部を示しています。

場所 説明

/mnt/var/log/bootstrap-actions

ブートストラップアクションの処理中に出力されるログ。

/mnt/var/log/hadoop-state-pusher

Hadoop の状態プッシャープロセスで出力されるログ。

/mnt/var/log/instance-controller (Amazon EMR 4.6.0 以前)

/emr/instance-controller (Amazon EMR 4.7.0 以降)

インスタンスコントローラログ。

/mnt/var/log/instance-state

インスタンス状態ログ。ノードの CPU、メモリの状態、およびガベージコレクタースレッドに関する情報が含まれます。

/mnt/var/log/service-nanny (Amazon EMR 4.6.0 以前)

/emr/service-nanny (Amazon EMR 4.7.0 以降)

サービスナニープロセスで出力されるログ

/mnt/var/log/application

Hadoop、Spark、Hive などのアプリケーションに固有のログ。

mnt/var/log/hadoop/steps/N

ステップの処理に関する情報が含まれステップログ。値NAmazon EMR によって割り当てられた stepId を示します。たとえば、クラスターに 2 つのステップ、s-1234ABCDEFGHs-5678IJKLMNOP があるとします。最初のステップは /mnt/var/log/hadoop/steps/s-1234ABCDEFGH/ に配置され、2 番目のステップは /mnt/var/log/hadoop/steps/s-5678IJKLMNOP/ に配置されます。

Amazon EMR によって書き込まれるステップログは次のとおりです。

  • コントローラ— ステップの処理に関する情報。ロード中にステップが失敗した場合は、このログにスタックトレースがあります。

  • syslog— ステップでの Hadoop ジョブの実行について説明します。

  • stderr— ステップの処理中の Hadoop の標準エラーチャンネルです。

  • stdout— ステップを処理している間の Hadoop の標準出力チャンネル。

マスターノードでログファイルを表示するには

  1. SSH を使用してマスターノードConnect する」の説明に従って、SSH を使用してマスターノードに接続します。

  2. 表示するログファイル情報が保存されているディレクトリに移動します。前述の表は、使用できるログファイルの種類とその保存場所の一覧です。次の例は、ID が s-1234ABCDEFGH のステップログに移動するコマンドを示しています。

    cd /mnt/var/log/hadoop/steps/s-1234ABCDEFGH/
  3. 任意のファイルビューワーを使用してログファイルを表示します。次の例では、Linux の less コマンドを使用して controller ログファイルを表示します。

    less controller

Amazon S3 にアーカイブされたログファイルの表示

デフォルトでは、コンソールを使用して起動した Amazon EMR クラスターは自動的に Amazon S3 にログファイルをアーカイブします。独自のログのパスを指定したり、コンソールが自動的にログのパスを生成することを許可したりできます。CLI または API を使用して起動されるクラスターについては、Amazon S3 ログのアーカイブを手動で設定する必要があります。

ログファイルを Amazon S3 にアーカイブするように Amazon EMR を設定している場合、指定した S3 の場所にファイルが保存されます。この例では、/cluster-id/フォルダ、場所cluster-idは、クラスター ID です。

次の表は、Amazon S3 に保存されるログファイルの一部を示しています。

場所 説明

/cluster-id/ノード/

ブートストラップアクション、インスタンスの状態、ノードのアプリケーションログを含むノードログ。各ノードのログは、そのノードの EC2 インスタンス識別子が名前に付いたフォルダーに保存されます。

/cluster-id/ノード/instance-id/アプリケーション

アプリケーションに関連付けられた各アプリケーションまたはデーモンにより作成されたログ。たとえば、Hive サーバーログは cluster-id/node/instance-id/hive/hive-server.log にあります。

/cluster-id/ステップ/ステップ ID/

ステップの処理に関する情報が含まれステップログ。値ステップ IDは、Amazon EMR によって割り当てられたステップ ID を示します。たとえば、クラスターに 2 つのステップ、s-1234ABCDEFGHs-5678IJKLMNOP があるとします。最初のステップは /mnt/var/log/hadoop/steps/s-1234ABCDEFGH/ に配置され、2 番目のステップは /mnt/var/log/hadoop/steps/s-5678IJKLMNOP/ に配置されます。

Amazon EMR によって書き込まれるステップログは次のとおりです。

  • コントローラ— ステップの処理に関する情報。ロード中にステップが失敗した場合は、このログにスタックトレースがあります。

  • syslog— ステップでの Hadoop ジョブの実行について説明します。

  • stderr— ステップの処理中の Hadoop の標準エラーチャンネルです。

  • stdout— ステップを処理している間の Hadoop の標準出力チャンネル。

/cluster-id/コンテナ

アプリケーションコンテナログ。各 YARN アプリケーションのログは、これらの場所に保存されます。

/cluster-id/hadoop-mapreduce/

MapReduce ジョブの設定の詳細とジョブ履歴に関する情報を含むログ。

コンソールを使用して Amazon S3 にアーカイブされたログファイルを表示するには

  1. AWS Management Console にサインインし、Amazon S3 コンソール (https://console.aws.amazon.com/s3/) を開きます。

  2. Amazon S3 でログファイルをアーカイブするようにクラスターを設定したときに指定した S3 バケットを開きます。

  3. 表示する情報を含むログファイルに移動します。前述の表は、使用できるログファイルの種類とその保存場所の一覧です。

  4. ログファイルオブジェクトをダウンロードして表示します。手順については、以下を参照してください。オブジェクトのダウンロード

デバッグツールでのログファイルの表示

Amazon EMR では、デバッグツールは自動的に有効になりません。クラスターの起動時にこれを設定する必要があります。

コンソールを使用してクラスターログを表示するには

  1. Amazon EMR コンソール (https://console.aws.amazon.com/elasticmapreduce/) を開きます。

  2. から、クラスター一覧ページで、表示するクラスターの横にある詳細アイコンを選択します。

    これにより、クラスターの詳細ページで. 左ステップセクションでは、各ステップの右側にあるリンクに、そのステップで使用可能なさまざまな種類のログが表示されます。これらのログは Amazon EMR によって生成されます。

  3. 特定のステップに関連付けられた Hadoop ジョブのリストを表示するには、ジョブの表示ステップの右側にある [リンク] をクリックします。

  4. 特定のジョブに関連付けられた Hadoop タスクのリストを表示するには、タスクの表示ジョブの右側にある [リンク] をクリックします。

  5. タスクが完了しようとしている間に実行された試行のリストを表示するには、試行の表示タスクの右側にある [リンク] をクリックします。

  6. タスク試行によって生成されたログを表示するには、stderr,stdout, およびsyslogは、タスクの試行の右側にリンクします。

Amazon EMR が Amazon S3 のバケットにログファイルをアップロードすると、デバッグツールには、ログファイルへのリンクが表示されます。ログファイルは 5 分ごとに Amazon S3 にアップロードされるため、ステップが完了してからログファイルのアップロードが完了するまでには、数分間かかることがあります。

Amazon EMR は、デバッグツールに表示される Hadoop のジョブ、タスク、およびタスク試行の状態を定期的に更新します。デバッグペインの [Refresh List] をクリックすると、これらの項目の最新のステータスを入手できます。