ログファイルを表示する - 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 を参照してください。

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

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

場所 説明

/emr/instance-controller /log/bootstrap-action

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

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

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

/emr/instance-controller/

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

/emr/instance-state

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

/emr/service-nanny

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

/mnt/var/log/application

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

mnt/var/log/hadoop/steps/N

ステップの処理に関する情報が含まれステップログ。の価値Nは Amazon 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 がステップを処理している間の Hadoop の標準エラーチャネル。

  • stdout— Hadoop がステップを処理している間の 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 EMR がログファイルを Amazon S3 にアーカイブするようにを設定している場合、指定した S3 の場所にファイルが保存されます。cluster-id/フォルダ、どこcluster-idは、クラスター ID です。

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

場所 説明

/cluster-id/node/

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

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

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

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

ステップの処理に関する情報が含まれステップログ。の価値step-idAmazon 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 がステップを処理している間の Hadoop の標準エラーチャネル。

  • stdout— Hadoop がステップを処理している間の 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] をクリックすると、これらの項目の最新のステータスを入手できます。