17

logstash を介して ES に送信する JSON ファイルがあります。値が NULL の場合のみ、JSON の 1 つのフィールド (深いフィールドです) を削除したいと思います。

JSON の一部は次のとおりです。

"input": {
        "startDate": "2015-05-27",
        "numberOfGuests": 1,
        "fileName": "null",
        "existingSessionId": "XXXXXXXXXXXXX",
        **"radius": "null",**
        "nextItemReference": "51",
        "longitude": -99.12,
        "endDate": "2015-05-29",
        "thumbnailHeight": 200,
        "thumbnailWidth": 300,
        "latitude": 19.42,
        "numOfRooms": "1"
    },

logstash.confファイルの一部は次のとおりです。

if [input.radius] == "null" {
                mutate {
                        remove_field => [ "input.radius" ]
                }
        }

もちろんフィルターの内側です。

値が null の場合、このフィールドを削除するにはどうすればよいですか?

4

1 に答える 1

30

ネストされたフィールドは[name.subfield]butで参照されません[field][subfield]。これはあなたのために働くはずです:

if [input][radius] == "null" {
  mutate {
    remove_field => [ "[input][radius]" ]
  }
}

「入力」フィールドがない場合、[input][radius]参照によって空の「入力」辞書が作成されることに注意してください。これを回避するには、次のようにします。

if [input] and [input][radius] == "null" {
  mutate {
    remove_field => [ "[input][radius]" ]
  }
}

詳細とその他の例については、Logstash のドキュメントを参照してください。

于 2015-05-21T09:57:20.800 に答える