Logstash Pipelines

Logstash comes with a customized configuration that meets the requirements of service.monitor Analytics. This includes multiple data pipelines, schema templates for Elasticsearch, and the central configuration file pipelines.yml. When Logstash is delivered, the file is not available and by using the supplied pipelines.yml you can use Logstash with multiple pipelines.

Typical file locations are:

File or folder Linux Windows

pipelines.yml

/etc/logstash/pipelines.yml

[Installationsverzeichnis]/config

ct-arcgis

/etc/logstash/conf.d/ct-arcgis

[Installationsverzeichnis]/config/ct-arcgis

ct-[n]

/etc/logstash/conf.d/ct-[n]

[Installationsverzeichnis]/config/ct-[n]

The files of the deployment need to be copied into the directories mentioned above depending on the operating system and installation type. Depending on requirements, individual folders can be skipped if the data source is not to be included. Afterwards the file pipelines.yml must be edited. The variable PIPELINES_PATH must be set in a system variable.

pipelines.yml
- pipeline.id: ct-analytics
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-analytics/*.conf"
- pipeline.id: ct-fme
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-fme-jobs/*.conf"
- pipeline.id: ct-fme-log
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-fme-log/*.conf"
- pipeline.id: ct-fme-jobroutes
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-fme-jobroutes/*.conf"
- pipeline.id: ct-log
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-log/*.conf"
- pipeline.id: ct-monitoring
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-monitoring/*.conf"
- pipeline.id: ct-arcgis-logfile
path.config: "${PIPELINES_PATH:/etc/logstash/conf.d}/ct-arcgis-logfile/*.conf"
yml

If e.g. the pipelines ct-log, ct-arcgis-logfile and ct-monitoring should be operated, then all other pipelines must be removed from the file or commented out by #.

Logstash uses one TCP/UDP port (e.g. 12201, 12202, 12203) per data pipeline when using service.monitor. Please check if access to this port from outside (depending on the purpose of use) is allowed by your firewall!

Use of variables

Normally, no content changes need to be made in the files of the logstash pipelines, as these can dynamically resolve to system variables.

Different options are available for this

  1. pass all system-specific values into system variables before starting the logstash process.

    install linux environment variables
    Setting Logstash Pipeline variables via /etc/default/logstash

    The recommended way to set variables is configuring these in /etc/default/logstash. Another example for setting these values beforehand can be found in the files bin/logstash_env.bat and bin/logstash_env.sh.

  2. Windows users can also set these values via Set NSSM.

Variables overview

Variable default explanation

PIPELINES_PATH

/etc/logstash/conf.d

Specify the file system folder in which service.monitor’s logstash pipelines are located.

ES_HOST

localhost

Specify the address of Elasticsearch, e.g. "127.0.0.1" or "https://elastic.server.example/extrapath"

ES_USER

<empty>

User name for authentication with Elasticsearch

ES_PASSWORD

<empty>

Password for authentication with Elasticsearch

FME_SERVER_BASE_URL

<empty>

URL of the host on which FME is running, incl. protocol, e.g.: https://fme.server.example/

FME_SERVER_TOKEN

<empty>

FME Server Token for authentication of the request at FME

FME_SERVER_LIMIT

1000

Number of jobs to be queried per request at FME Server

FME_SERVER_SCHEDULE

6h

Polling interval for FME Server jobs