

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

# Amazon EMR クラスターの出力を圧縮する方法
<a name="emr-plan-output-compression"></a>

データ処理から生じる出力を圧縮する方法はさまざまです。使用する圧縮ツールは、データのプロパティによって異なります。圧縮は、大量のデータを転送する際にパフォーマンスを向上させることができます。

## 出力データ圧縮
<a name="HadoopOutputDataCompression"></a>

 Hadoop ジョブの出力を圧縮します。TextOutputFormat を使用している場合、結果はテキストファイルに gzip を実行することによって得られます。SequenceFiles に書き込む場合は、内部的に圧縮された SequenceFile が結果として得られます。これは、mapred.output.compress を true に設定することによって有効にできます。

 ストリーミングジョブを実行している場合は、そのストリーミングジョブにこれらの引数を渡すことで有効にできます。

```
1. -jobconf mapred.output.compress=true
```

 また、ブートストラップアクションを使用することによって自動的にすべてのジョブ出力を圧縮することもできます。ここでは、Ruby クライアントでこれを行う方法を示します。

```
1.    
2. --bootstrap-actions s3://elasticmapreduce/bootstrap-actions/configure-hadoop \
3. --args "-s,mapred.output.compress=true"
```

 最後に、Custom Jar を作成している場合は、ジョブの作成時に次の行を使用して出力圧縮を有効にすることができます。

```
1. FileOutputFormat.setCompressOutput(conf, true);
```

## 中間データ圧縮
<a name="HadoopIntermediateDataCompression"></a>

 マッパーからリデューサーに大量のデータを移動するジョブでは、中間圧縮を行うことでパフォーマンスが大幅に向上することがあります。マップ出力を圧縮し、コアノードに到達したらそれを解凍します。設定は、mapred.compress.map.output で行います。これは、出力圧縮についても同様に有効にすることができます。

 Custom Jar を作成している場合は、次のコマンドを使用します。

```
1. conf.setCompressMapOutput(true);
```

## Amazon EMR での Snappy ライブラリの使用
<a name="emr-using-snappy"></a>

Snappy は高速圧縮/解凍ライブラリです。Amazon EMR AMI バージョン 2.0 以降で使用でき、中間圧縮用のデフォルトとして使用されています。Snappy の詳細については、[http://code.google.com/p/snappy/](http://code.google.com/p/snappy/) を参照してください。