Skip to content

Commit

Permalink
Change template loading to be part of the setup (#4080)
Browse files Browse the repository at this point in the history
* Change config option to setup.template.* from outputs.elasticsearch.template.*
* Move loading logic into template package
* Remove template loading logic from elasticsearch output
* Changelog updated
* Template tests were moved from output to template package
* Documentation was updated. Will need some more work for which a follow up Github issue will be created.
* Add `GetVersion()` to elasticsearch client.
* Introduce callback registration for elasticsearch output. This should be generalised later. The template loading registers only with the output client factory which means, the template is not loaded when connecting for loading dashboards, pipeline or monitoring data which is intended.

This is only migration the existing options. New options like outputting to a json file or load additional config options will be added in a follow up PR.

Part of #3654 and #3921
  • Loading branch information
ruflin authored and tsg committed May 4, 2017
1 parent 3b16d06 commit 4ae0b89
Show file tree
Hide file tree
Showing 25 changed files with 544 additions and 487 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ https://github.com/elastic/beats/compare/v5.1.1...master[Check the HEAD diff]
- Change vendor manager from glide to govendor. {pull}3851[3851]
- Rename `error` field to `error.message`. {pull}3987[3987]
- Change `dashboards.*` config options to `setup.dashboards.*`. {pull}3921[3921]
- Change `outputs.elasticsearch.template.* to `setup.template.*` {pull}4080[4080]

*Filebeat*
- Always use absolute path for event and registry. This can lead to issues when relative paths were used before. {pull}3328[3328]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -596,7 +596,7 @@ include::../../../../libbeat/docs/outputconfig.asciidoc[]

include::../../../../libbeat/docs/shared-path-config.asciidoc[]

include::../../../../libbeat/docs/dashboardsconfig.asciidoc[]
include::../../../../libbeat/docs/setup-config.asciidoc[]

include::../../../../libbeat/docs/loggingconfig.asciidoc[]

Expand Down
39 changes: 21 additions & 18 deletions filebeat/filebeat.full.yml
Original file line number Diff line number Diff line change
Expand Up @@ -559,24 +559,6 @@ output.elasticsearch:
# requests are made.
#flush_interval: 1s

# A template is used to set the mapping in Elasticsearch
# By default template loading is enabled and the template is loaded.
# These settings can be adjusted to load your own template or overwrite existing ones.

# Set to false to disable template loading.
#template.enabled: true

# Template name. By default the template name is filebeat.
# The version of the beat will always be appended to the given name
# so the final name is filebeat-%{[beat.version]}.
#template.name: "filebeat"

# Path to fields.yml file to generate the template
#template.fields: "${path.config}/fields.yml"

# Overwrite existing template
#template.overwrite: false

# Use SSL settings for HTTPS. Default is true.
#ssl.enabled: true

Expand Down Expand Up @@ -1003,6 +985,27 @@ output.elasticsearch:
# dashboards and index pattern. Example: testbeat-*
#setup.dashboards.index:

#============================== Template =====================================

# A template is used to set the mapping in Elasticsearch
# By default template loading is enabled and the template is loaded.
# These settings can be adjusted to load your own template or overwrite existing ones.

# Set to false to disable template loading.
#setup.template.enabled: true

# Template name. By default the template name is filebeat.
# The version of the beat will always be appended to the given name
# so the final name is filebeat-%{[beat.version]}.
#setup.template.name: "filebeat"

# Path to fields.yml file to generate the template
#setup.template.fields: "${path.config}/fields.yml"

# Overwrite existing template
#setup.template.overwrite: false


#================================ HTTP Endpoint ======================================
# Each beat can expose internal data points through a http endpoint. For security
# reason the endpoint is disabled by default. This feature is currently in beta.
Expand Down
48 changes: 24 additions & 24 deletions heartbeat/docs/reference/configuration/heartbeat-options.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ The `heartbeat` section of the +heartbeat.yml+ config file specifies the
list of `monitors` that Heartbeat uses to check your remote hosts to
determine if they are available. Each `monitor` item begins with a dash (-) and
specifies the type of monitor to use, the hosts to check, and other settings
that control Heartbeat behavior.
that control Heartbeat behavior.

The following example configures three monitors, `icmp`, `tcp`, and `http`, and
demonstrates how to use TCP Echo and HTTP response verification:
Expand Down Expand Up @@ -35,7 +35,7 @@ heartbeat.scheduler:
You can specify the following options in the `monitors` section of the
+heartbeat.yml+ config file. These options are the same for all monitors.
Each monitor type has additional configuration options that are specific to that
monitor type.
monitor type.


[[monitor-type]]
Expand All @@ -51,7 +51,7 @@ receiving a custom payload. See <<monitor-tcp-options>>.
expected response. See <<monitor-http-options>>.

The `tcp` and `http` monitor types both support SSL/TLS and some proxy
settings.
settings.


[[monitor-name]]
Expand Down Expand Up @@ -133,7 +133,7 @@ you can specify settings in the JSON file that overwrite the settings in
the main config. In this way, the configuration that you specify for the
monitor in the main Heartbeat config file acts like a default config that you
can live-reconfigure by specifying additional configurations in the external
JSON file.
JSON file.

Example configuration:

Expand All @@ -148,21 +148,21 @@ heartbeat.monitors:
interval: 5s
-------------------------------------------------------------------------------

*`path`*:: Specifies the path to the JSON file to check for updates.
*`path`*:: Specifies the path to the JSON file to check for updates.
*`interval`*:: Specifies how often Heartbeat checks the file for changes.

To reconfigure the settings specified in the example config, you could define
the following JSON objects in `dynamic.json`:

[source, json]
-------------------------------------------------------------------------------
{"hosts": ["myhost:1234"], "schedule": "*/15 * * * * * *"} <1>
{"hosts": ["myhost:1234"], "schedule": "*/15 * * * * * *"} <1>
{"hosts": ["tls://otherhost:479"], "ssl.certificate_authorities": ["path/to/ca/file.pem"]} <2>
-------------------------------------------------------------------------------
<1> Upon detecting the changes, Heartbeat stops the old monitor and then
restarts it with a schedule of 15 seconds between checks.
<2> Heartbeat starts a new monitor that uses a TLS-based connection with a
custom CA certificate.
custom CA certificate.

[[monitor-icmp-options]]
==== ICMP Options
Expand Down Expand Up @@ -222,7 +222,7 @@ Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
- type: tcp
- type: tcp
schedule: '@every 5s'
hosts: ["myhost"]
ports: [80, 9200, 5044]
Expand All @@ -242,7 +242,7 @@ Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
- type: tcp
- type: tcp
schedule: '@every 5s'
hosts: ["myhost"]
ports: [7]
Expand All @@ -255,7 +255,7 @@ Example configuration:
===== proxy_url

The URL of the SOCKS5 proxy to use when connecting to the server. The value
must be a URL with a scheme of socks5://.
must be a URL with a scheme of socks5://.

If the SOCKS5 proxy server requires client authentication, then a username and
password can be embedded in the URL as shown in the example.
Expand Down Expand Up @@ -289,7 +289,7 @@ Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
- type: tcp
- type: tcp
schedule: '@every 5s'
hosts: ["myhost"]
ports: [80, 9200, 5044]
Expand All @@ -315,7 +315,7 @@ Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
- type: http
- type: http
schedule: '@every 5s'
urls: ["http://myhost:80"]
-------------------------------------------------------------------------------
Expand All @@ -331,11 +331,11 @@ environment variable is used.
===== username

The username for authenticating with the server. The credentials are passed
with the request. This setting is optional.
with the request. This setting is optional.

You need to specify credentials when your `check.response` settings require it.
For example, you can check for a 403 response (`check.response.status: 403`)
without setting credentials.
without setting credentials.

[[monitor-http-password]]
===== password
Expand All @@ -346,32 +346,32 @@ The password for authenticating with the server. This setting is optional.
===== ssl

The TLS/SSL connection settings for use with the HTTPS endpoint. If you don't
specify settings, the system defaults are used.
specify settings, the system defaults are used.


Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
- type: http
- type: http
schedule: '@every 5s'
urls: ["https://myhost:80"]
ssl:
certificate_authorities: ['/etc/ca.crt']
supported_protocols: ["TLSv1.0", "TLSv1.1", "TLSv1.2"]
supported_protocols: ["TLSv1.0", "TLSv1.1", "TLSv1.2"]
-------------------------------------------------------------------------------


[[monitor-http-check]]
===== check

An optional `request` to send to the remote host and the expected `response`.
An optional `request` to send to the remote host and the expected `response`.

Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
- type: http
- type: http
schedule: '@every 5s'
urls: ["http://myhost:80"]
check.request.method: HEAD
Expand All @@ -389,16 +389,16 @@ Under `check.request`, specify these options:
Under `check.response`, specify these options:

*`status`*:: The expected status code. If this setting is not configured or
it's set to 0, any status code other than 404 is accepted.
*`headers`*:: The required response headers.
it's set to 0, any status code other than 404 is accepted.
*`headers`*:: The required response headers.
*`body`*:: The required response body content.

The following configuration shows how to check the response when the body
contains JSON:

[source,yaml]
-------------------------------------------------------------------------------
- type: http
- type: http
schedule: '@every 5s'
urls: ["https://myhost:80"]
check.request:
Expand All @@ -417,7 +417,7 @@ check.response:
You specify options under `scheduler` to control the behavior of the task
scheduler.

Example configuration:
Example configuration:

[source,yaml]
-------------------------------------------------------------------------------
Expand Down Expand Up @@ -452,7 +452,7 @@ include::../../../../libbeat/docs/outputconfig.asciidoc[]

include::../../../../libbeat/docs/shared-path-config.asciidoc[]

include::../../../../libbeat/docs/dashboardsconfig.asciidoc[]
include::../../../../libbeat/docs/setup-config.asciidoc[]

include::../../../../libbeat/docs/loggingconfig.asciidoc[]

Expand Down
39 changes: 21 additions & 18 deletions heartbeat/heartbeat.full.yml
Original file line number Diff line number Diff line change
Expand Up @@ -339,24 +339,6 @@ output.elasticsearch:
# requests are made.
#flush_interval: 1s

# A template is used to set the mapping in Elasticsearch
# By default template loading is enabled and the template is loaded.
# These settings can be adjusted to load your own template or overwrite existing ones.

# Set to false to disable template loading.
#template.enabled: true

# Template name. By default the template name is heartbeat.
# The version of the beat will always be appended to the given name
# so the final name is heartbeat-%{[beat.version]}.
#template.name: "heartbeat"

# Path to fields.yml file to generate the template
#template.fields: "${path.config}/fields.yml"

# Overwrite existing template
#template.overwrite: false

# Use SSL settings for HTTPS. Default is true.
#ssl.enabled: true

Expand Down Expand Up @@ -783,6 +765,27 @@ output.elasticsearch:
# dashboards and index pattern. Example: testbeat-*
#setup.dashboards.index:

#============================== Template =====================================

# A template is used to set the mapping in Elasticsearch
# By default template loading is enabled and the template is loaded.
# These settings can be adjusted to load your own template or overwrite existing ones.

# Set to false to disable template loading.
#setup.template.enabled: true

# Template name. By default the template name is heartbeat.
# The version of the beat will always be appended to the given name
# so the final name is heartbeat-%{[beat.version]}.
#setup.template.name: "heartbeat"

# Path to fields.yml file to generate the template
#setup.template.fields: "${path.config}/fields.yml"

# Overwrite existing template
#setup.template.overwrite: false


#================================ HTTP Endpoint ======================================
# Each beat can expose internal data points through a http endpoint. For security
# reason the endpoint is disabled by default. This feature is currently in beta.
Expand Down
39 changes: 21 additions & 18 deletions libbeat/_meta/config.full.yml
Original file line number Diff line number Diff line change
Expand Up @@ -141,24 +141,6 @@ output.elasticsearch:
# requests are made.
#flush_interval: 1s

# A template is used to set the mapping in Elasticsearch
# By default template loading is enabled and the template is loaded.
# These settings can be adjusted to load your own template or overwrite existing ones.

# Set to false to disable template loading.
#template.enabled: true

# Template name. By default the template name is beatname.
# The version of the beat will always be appended to the given name
# so the final name is beatname-%{[beat.version]}.
#template.name: "beatname"

# Path to fields.yml file to generate the template
#template.fields: "${path.config}/fields.yml"

# Overwrite existing template
#template.overwrite: false

# Use SSL settings for HTTPS. Default is true.
#ssl.enabled: true

Expand Down Expand Up @@ -585,6 +567,27 @@ output.elasticsearch:
# dashboards and index pattern. Example: testbeat-*
#setup.dashboards.index:

#============================== Template =====================================

# A template is used to set the mapping in Elasticsearch
# By default template loading is enabled and the template is loaded.
# These settings can be adjusted to load your own template or overwrite existing ones.

# Set to false to disable template loading.
#setup.template.enabled: true

# Template name. By default the template name is beatname.
# The version of the beat will always be appended to the given name
# so the final name is beatname-%{[beat.version]}.
#setup.template.name: "beatname"

# Path to fields.yml file to generate the template
#setup.template.fields: "${path.config}/fields.yml"

# Overwrite existing template
#setup.template.overwrite: false


#================================ HTTP Endpoint ======================================
# Each beat can expose internal data points through a http endpoint. For security
# reason the endpoint is disabled by default. This feature is currently in beta.
Expand Down
Loading

0 comments on commit 4ae0b89

Please sign in to comment.