community.general.logstash callback – Sends events to Logstash

Note

This callback plugin is part of the community.general collection (version 10.0.1).

You might already have this collection installed if you are using the ansible package. It is not included in ansible-core. To check whether it is installed, run ansible-galaxy collection list.

To install it, use: ansible-galaxy collection install community.general. You need further requirements to be able to use this callback plugin, see Requirements for details.

To use it in a playbook, specify: community.general.logstash.

Callback plugin

This plugin is a notification callback. It sends information for a playbook run to other applications, services, or systems. See Callback plugins for more information on callback plugins.

Synopsis

Requirements

The below requirements are needed on the local controller node that executes this callback.

  • whitelisting in configuration

  • logstash (Python library)

Parameters

Parameter

Comments

format_version

string

added in community.general 2.0.0

Logging format.

Choices:

  • "v1" ← (default)

  • "v2"

Configuration:

port

integer

Port on which logstash is listening.

Default: 5000

Configuration:

  • INI entry:

    [callback_logstash]
    port = 5000
    

    added in community.general 1.0.0

  • Environment variable: LOGSTASH_PORT

pre_command

string

added in community.general 2.0.0

Executes command before run and its result is added to the ansible_pre_command_output logstash field.

Configuration:

server

string

Address of the Logstash server.

Default: "localhost"

Configuration:

  • INI entry:

    [callback_logstash]
    server = localhost
    

    added in community.general 1.0.0

  • Environment variable: LOGSTASH_SERVER

type

string

Message type.

Default: "ansible"

Configuration:

  • INI entry:

    [callback_logstash]
    type = ansible
    

    added in community.general 1.0.0

  • Environment variable: LOGSTASH_TYPE

Examples

ansible.cfg: |
    # Enable Callback plugin
    [defaults]
        callback_whitelist = community.general.logstash

    [callback_logstash]
        server = logstash.example.com
        port = 5000
        pre_command = git rev-parse HEAD
        type = ansible

11-input-tcp.conf: |
    # Enable Logstash TCP Input
    input {
            tcp {
                port => 5000
                codec => json
                add_field => { "[@metadata][beat]" => "notify" }
                add_field => { "[@metadata][type]" => "ansible" }
            }
        }

Authors

  • Yevhen Khmelenko (@ujenmr)

Hint

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.