Skip to content
This repository has been archived by the owner on Jan 19, 2022. It is now read-only.

ministryofjustice/logstash-formula

logstash

Formulas to set up and configure the logstash server, or ship logs into a central server.

Dependencies

Note

This formula has a dependency on the following salt formulas:

bootstrap

utils

elasticsearch

java

redis (the one from MoJ, not the saltstack-formulas community repo)

python

firewall

nginx

Available states

Install logstash from the system package manager and start the service. This has been tested only on Ubuntu 12.04.

Example usage:

include:
  - logstash.server
  • kibana:elasticsearch

    The URL at which the ElasticSearch server can be reached by the client browser. The default is to take the current host:port and replace the 'kibana' part of the hostname with 'elasticsearch' - override this if it is not what you want.

  • monitoring:enabled (default True)

    Used to configure whether monitoring should be enabled/installed at all. It's useful as client side of monitoring is an implicit dependency.

  • syslog:udp_enabled (default True)

    Used to configure whether rsyslogd should forward logs to udp. Set to true by default just for compatibility reasons, but only needed if an endpoint is listening there. Set this to False when using just logstash.client (without logstash.server).

  • monitoring:ns (future) TODO: Monitoring shall prefix the metrics using this value.

Note

The formula sets common defaults so in most cases will only require the states to be loaded in the top.sls file.

Install beaver for the ability to ship logs to the central logstash server over the redis connection specified in the pillar (with a default of localhost db #0).

Example usage:

include:
  - logstash.client

Example pillar:

beaver:
  redis:
    host: logstash.local
    port: 6379
    namespace: logstash:beaver
    db: 0
    queue_timeout: 60

You can enable and disable client plugins as below, showing the default values.

Enabling and disabling client plugins:

beaver:
   activate_plugins:
      - salt-master: True
        salt-minion: True
        salt-key: True
        auditd: False

Macro to ship a given log file with beaver to central logstash server.

The macro has the following arguments:

appshort
A unique tag for the logfile to ship
logfile
The path of the log to monitor and ship
type

The type of the entries in this log file. Shows up as the type field in logstash.

Default: daemon

tags

List of tags to apply to every message.

Default: daemon, error

format

Format to use when sending to logstash. If you have just a line of text this should be json - if you are already output json to the log then you want this to be rawjson

Default: json

absent

Boolean flag to force configuration file removal. Deleting a macro call will not remove the configuration file on highstate. Possible values: true or false

Default: false

Example usage:

include:
  - logstash.client

{% from 'logstash/lib.sls' import logship with context %}
{{ logship('redis-server.log', '/var/log/redis/redis-server.log', 'redis', ['redis','log'], 'json') }}
{{ logship('redis-server.log', '/var/log/redis/redis-server.log', 'redis', ['redis','log'], 'json', absent=true) }}

Installs a cron job that runs a scanner against containers looking for stunnel certificates then logs this to a file /var/log/cron.log

{
  "timestamp": "2017-06-09 18:54:01,924",
  "name": "logstash:stunnel-scanner",
  "level": "INFO",
  "level_no": 20,
  "message": "Found stunnel container envs",
  "notAfter": "20180608153600Z",
  "notAfterDate": "2018-06-08T15:36:00",
  "hasExpired": "0",
  "containerId": "a132221b843b6f293ace11233a5ed37768fbaae8c1d1744c2a1b0d1d81f71c5a",
  "signatureAlgorithm": "ecdsa-with-SHA512"
}

apparmor

This formula includes some simple default apparmor profiles for beaver, and adds additions to the nginx profile to allow access to kibana and grafana webroots.

App armor is by default in complain mode which means it allows the action and logs. To make it deny actions that the beaver profile doesn't cover set the following pillar:

apparmor:
  profiles:
    beaver:
      enforce: ''
    # We need to set the same mode on nginx for kibana and grafana too
    nginx:
      encorce: ''

Running Vagrant Tests

To run the test suite under Vagrant:

vagrant up vagrant ssh # if updates have been made: # salt-call state.highstate /vagrant/custom-test/run.sh