diff --git a/doc/14-features.md b/doc/14-features.md index 83617df44..312b3c809 100644 --- a/doc/14-features.md +++ b/doc/14-features.md @@ -347,7 +347,7 @@ The check results include parsed performance data metrics if enabled. > **Note** > -> Elasticsearch 5.x+ is required. +> Elasticsearch 5.x+ is required. This feature has been tested with Elasticsearch 5.6.4 and 6.0.0. Enable the feature and restart Icinga 2. diff --git a/lib/perfdata/elasticsearchwriter.cpp b/lib/perfdata/elasticsearchwriter.cpp index f113aef13..8b6441c87 100644 --- a/lib/perfdata/elasticsearchwriter.cpp +++ b/lib/perfdata/elasticsearchwriter.cpp @@ -396,6 +396,11 @@ void ElasticsearchWriter::Flush(void) String body = boost::algorithm::join(m_DataBuffer, "\n"); m_DataBuffer.clear(); + /* Elasticsearch 6.x requires a new line. This is compatible to 5.x. + * Tested with 6.0.0 and 5.6.4. + */ + body += "\n"; + SendRequest(body); } @@ -455,12 +460,20 @@ void ElasticsearchWriter::SendRequest(const String& body) try { resp.Parse(context, true); + while (resp.Parse(context, true) && !resp.Complete) + ; /* Do nothing */ } catch (const std::exception& ex) { Log(LogWarning, "ElasticsearchWriter") - << "Cannot read from HTTP API on host '" << GetHost() << "' port '" << GetPort() << "'."; + << "Failed to parse HTTP response from host '" << GetHost() << "' port '" << GetPort() << "': " << DiagnosticInformation(ex, false); throw ex; } + if (!resp.Complete) { + Log(LogWarning, "ElasticsearchWriter") + << "Failed to read a complete HTTP response from the Elasticsearch server."; + return; + } + if (resp.StatusCode > 299) { if (resp.StatusCode == 401) { /* More verbose error logging with Elasticsearch is hidden behind a proxy. */ @@ -479,10 +492,6 @@ void ElasticsearchWriter::SendRequest(const String& body) Log(LogWarning, "ElasticsearchWriter") << "Unexpected response code " << resp.StatusCode; - /* Finish parsing the headers and body. */ - while (!resp.Complete) - resp.Parse(context, true); - String contentType = resp.Headers->Get("content-type"); if (contentType != "application/json") { @@ -509,6 +518,8 @@ void ElasticsearchWriter::SendRequest(const String& body) Log(LogCritical, "ElasticsearchWriter") << "Elasticsearch error message:\n" << error; + + return; } }