LoginSignup
2
1

More than 3 years have passed since last update.

Logstashが実装するS3プラグイン(input/output)の活用について

Posted at

目的

 LogstashにはS3内のデータを抽出(Input)したり、データを出力(Output)するプラグインが存在します。Logstashプラグインのサポートについての記事にて解説した通り、両プラグイン供にTier1のプラグインであり、Elastic社の有償サポートに加入している場合はプロダクト保証があります。Inputプラグインの最新バージョンはversion: v3.4.1であリ、Outputプラグインの最新バージョンはversion: v3.4.1であります。
 本投稿では、それらプラグインの基本的な利用方法について解説します。Elastic社のマニュアルから、基本的な設定方法をピックアップして設定の勘所を記載します。それぞれのマニュアルは以下を参考にしました。
 

ダウンロード.png

S3 input plugin

Main Parameter

S3 input pluginで利用する主要パラメータについて、以下で解説します。基本的にはこれらのパラメータを設定するだけで良いですが、より応用的な使い方をしたい場合は、S3 input-plugin official document by Elasticを参照してください。

  • access_key_id: [string]
  • secret_access_key: [string]

    • S3にアクセスするためのcredential情報を記載します。コンフィグレーションファイルに、これらの情報を記載したくない場合は、credential情報が記載された別ファイルをパラメータで指定することも可能です。具体的には、aws_credentials_fileの値を設定します。
  • aws_credentials_file [string]

    • AWS credential情報が格納されたyamlファイルのpath情報です。このパラメータは、access_key_idsecret_access_keyのパラメータが設定されていない場合にのみ、読み込まれます。
  • bucket [string]

    • S3 bucketの名前。Logstashインスタンスからアクセス可能なS3 bucketを指定する必要があります。
  • region [string]

    • S3 bucketのRegion。デフォルト値はus-east-1のため、必要に応じて変更する必要があります。
  • delete [boolean]

    • trueに設定することで、データ抽出後にS3内のオリジナルデータを削除することができます。
  • temporary_directory [string]

    • S3から取得したデータを一時的に保管するディレクトリ。デフォルトのディレクトリパスは、/tmp/logstashです。
  • watch_for_new_files [boolean]

    • S3に格納される新規ファイルを継続的に取得し続けるかどうかを設定します。
  • interval [number]

    • LogstashがS3にデータ取得するインターバル。デフォルトは60秒。
  • include_object_properties [boolean]

    • S3のオブジェクトプロパティをデータ取得対象にするか否かを決定します。
  • prefix [string]

    • データ取得対象のプレフィックス長を設定する。もし、設定されている場合、プレフィックスがマッチしたファイルに限り、Lostashのデータ取得対象となります。

Setting Example

以下にS3 input pluginの設定例を示します。

input_plugin_example
input {
  s3 {
    access_key_id => "<your-access_key_id>"
    secret_access_key => "<your-access_secret_access_key>"
    region => "<your-region>"
    bucket => "<your-bucket>"
    prefix => "Logs"
    interval => "10"
    delete => false
    watch_for_new_files => true
    include_object_properties => false
  }
}

S3 output plugin

Main Parameter

S3 output pluginで利用する主要パラメータについて、以下で解説します。基本的にはこれらのパラメータを設定するだけで良いですが、より応用的な使い方をしたい場合は、S3 output-plugin official document by Elasticを参照してください。

  • access_key_id: [string]
  • secret_access_key: [string]

    • S3にアクセスするためのcredential情報を記載します。コンフィグレーションファイルに、これらの情報を記載したくない場合は、credential情報が記載された別ファイルをパラメータで指定することも可能です。具体的には、aws_credentials_fileの値を設定します。
  • bucket [string]

    • S3 bucketの名前。Logstashインスタンスからアクセス可能なS3 bucketを指定する必要があります。
  • region [string]

    • S3 bucketのRegion。デフォルト値はus-east-1のため、必要に応じて変更する必要があります。
  • temporary_directory [string]

    • S3へデータ出力する前に使用する一時保管用のディレクトリ。デフォルトのディレクトリパスは、/tmp/logstashです。このディレクトリにS3へ格納する前のファイルが格納され、rotation_strategyなどで設定したローテーション方針に従い処理されることになります。
  • canned_acl [string]

    • 格納ファイルに対するアクセス制限。private, public-read, public-read-write, authenticated-read, aws-exec-read, bucket-owner-read, bucket-owner-full-control, log-delivery-writeから1つ選択します。デフォルト値は、privateです。
  • encoding [string]

    • 格納ファイルに対する圧縮方式。none, gzipから1つ選択する。デフォルト値は、nodeです。
  • upload_queue_size [number]

    • S3へアップロードする前にLogstashインスタンスのキュー内に保持する最大メッセージ数。デフォルト値は4です。
  • storage_class [string]

    • 格納ファイルのデータ保持方式。STANDARD, REDUCED_REDUNDANCY, STANDARD_IA, ONEZONE_IAから1つ選択します。デフォルト値は、STANDARDです。
  • restore [boolean]

    • Logstash異常終了時の回復機能利用有無を指定します。trueの場合、temporary_directory内のログファイルがrecoverされてuploadされます。デフォルト値は、trueです。
  • rotation_strategy [string]

    • 出力するファイルをローテーションするアルゴリズムを指定します。size_and_time, size, timeから1つ選択します。デフォルト値は、size_and_timeです。
  • size_file [number]

    • ローテーションするファイルサイズ(byte)を指定します。デフォルト値は、5242880bytesです。
  • time_file [number]

    • ローテーションするタイミング(分)を指定します。デフォルト値は、15分です。
  • prefix [string]

    • ファイル名のprefixを設定します。prefixで指定したオブジェクト名称で格納されます。

Setting Example

以下にS3 output pluginの設定例を示します。

output_plugin_example
output {
  s3{
    access_key_id => "<your-access_key_id>"
    secret_access_key => "<your-access_secret_access_key>"
    region => "<your-region>"
    bucket => "<your-bucket>"
    prefix => "test/%{+YYYY}/%{+MM}/%{+dd}"
    encoding => "gzip"
    rotation_strategy => "time"
    time_file => 1
  }
}

以上です。

2
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
1