Как запросить elasticsearch для конкретных данных визуализации kibana?

#elasticsearch #curl #kibana #elastic-stack #elk

#elasticsearch #curl #kibana #эластичный-стек #elk

Вопрос:

На панели мониторинга kibana нашего кластера я вижу визуализацию, которая дает мне общее количество входящего трафика в приложение. Что я хочу, так это получить такое же количество входящего трафика с помощью вызова curl, чтобы я мог автоматизировать некоторые отчеты. Для этого сначала я проверяю визуализацию и нажимаю на запрос, ниже приведено то, что я получил

 {
  "aggs": {},
  "size": 0,
  "_source": {
    "excludes": []
  },
  "stored_fields": [
    "*"
  ],
  "script_fields": {},
  "docvalue_fields": [
    {
      "field": "@timestamp",
      "format": "date_time"
    },
    {
      "field": "time",
      "format": "date_time"
    }
  ],
  "query": {
    "bool": {
      "must": [],
      "filter": [
        {
          "bool": {
            "filter": [
              {
                "bool": {
                  "must_not": {
                    "bool": {
                      "should": [
                        {
                          "query_string": {
                            "fields": [
                              "remote_addr"
                            ],
                            "query": "\1\0\.\0\.*"
                          }
                        }
                      ],
                      "minimum_should_match": 1
                    }
                  }
                }
              },
              {
                "bool": {
                  "filter": [
                    {
                      "bool": {
                        "must_not": {
                          "bool": {
                            "should": [
                              {
                                "query_string": {
                                  "fields": [
                                    "remote_addr"
                                  ],
                                  "query": "\1\0\0\.\0\.*"
                                }
                              }
                            ],
                            "minimum_should_match": 1
                          }
                        }
                      }
                    },
                    {
                      "bool": {
                        "filter": [
                          {
                            "bool": {
                              "must_not": {
                                "bool": {
                                  "should": [
                                    {
                                      "match_phrase": {
                                        "upstream_addr.keyword": “IP_ADDR:PORT”
                                      }
                                    }
                                  ],
                                  "minimum_should_match": 1
                                }
                              }
                            }
                          },
                          {
                            "bool": {
                              "filter": [
                                {
                                  "bool": {
                                    "must_not": {
                                      "bool": {
                                        "should": [
                                          {
                                            "match_phrase": {
                                              "upstream_addr.keyword": “IP_ADDR:PORT”
                                            }
                                          }
                                        ],
                                        "minimum_should_match": 1
                                      }
                                    }
                                  }
                                },
                                {
                                  "bool": {
                                    "filter": [
                                      {
                                        "bool": {
                                          "must_not": {
                                            "bool": {
                                              "should": [
                                                {
                                                  "match_phrase": {
                                                    "upstream_addr.keyword": “IP_ADDR:PORT”
                                                  }
                                                }
                                              ],
                                              "minimum_should_match": 1
                                            }
                                          }
                                        }
                                      },
                                      {
                                        "bool": {
                                          "must_not": {
                                            "bool": {
                                              "should": [
                                                {
                                                  "match_phrase": {
                                                    "upstream_addr.keyword": “IP_ADDR:PORT”
                                                  }
                                                }
                                              ],
                                              "minimum_should_match": 1
                                            }
                                          }
                                        }
                                      }
                                    ]
                                  }
                                }
                              ]
                            }
                          }
                        ]
                      }
                    }
                  ]
                }
              }
            ]
          }
        },
        {
          "match_all": {}
        },
        {
          "match_phrase": {
            "kubernetes.labels.app.keyword": {
              "query": "kong"
            }
          }
        },
        {
          "exists": {
            "field": "status"
          }
        },
        {
          "range": {
            "@timestamp": {
              "format": "strict_date_optional_time",
              "gte": "2021-01-05T09:32:46.946Z",
              "lte": "2021-01-05T09:47:46.946Z"
            }
          }
        }
      ],
      "should": [],
      "must_not": [
        {
          "bool": {
            "should": [
              {
                "match_phrase": {
                  "http_user_agent": "CloudWatchSynthetics"
                }
              },
              {
                "match_phrase": {
                  "http_user_agent": "Amazon-Route53-Health-Check-Service"
                }
              }
            ],
            "minimum_should_match": 1
          }
        }
      ]
    }
  }
}
 

Теперь я взял это тело запроса и сделал curl-вызов elasticsearch, как показано ниже

 curl -u elastic:password -x GET "localhost:9200/_mget?pretty" -H 'Content-Type: application/json' -d'
<request_body_that_I_have_pasted_above>
'
 

Но это приводит к ошибке ниже

 {
  "error" : {
    "root_cause" : [
      {
        "type" : "parsing_exception",
        "reason" : "unexpected token [START_OBJECT], expected [FIELD_NAME] or [START_ARRAY]",
        "line" : 3,
        "col" : 11
      }
    ],
    "type" : "parsing_exception",
    "reason" : "unexpected token [START_OBJECT], expected [FIELD_NAME] or [START_ARRAY]",
    "line" : 3,
    "col" : 11
  },
  "status" : 400
}
 

Правильный ли мой подход? что я здесь делаю не так?