The following configuration example shows how to configure a Collector instance to receive data from syslog and send it to the Dynatrace backend.
receivers:syslog/f5:tcp:listen_address: "0.0.0.0:54526"protocol: rfc5424operators:- type: addfield: attributes.log.sourcevalue: syslog- type: addfield: attributes.dt.ip_addressesvalue: "1xx.xx.xx.xx1"- type: addfield: attributes.instance.namevalue: "ip-1xx-xx-x-xx9.ec2.internal"- type: addfield: attributes.device.typevalue: "f5bigip"syslog/host:tcp:listen_address: "0.0.0.0:54527"protocol: rfc5424operators:- type: addfield: attributes.log.sourcevalue: syslog- type: addfield: attributes.device.typevalue: "ubuntu-syslog"processors:attributes:actions:- key: net.host.nameaction: delete- key: net.peer.nameaction: delete- key: net.peer.portaction: delete- key: net.transportaction: delete- key: net.host.ipaction: delete- key: dt.ingest.portfrom_attribute: net.host.portaction: upsert- key: dt.ingest.source.ipfrom_attribute: net.peer.ipaction: upsert- key: net.peer.ipaction: delete- key: net.host.portaction: delete- key: syslog.hostnamefrom_attribute: hostnameaction: upsert- key: hostnameaction: delete- key: syslog.facilityfrom_attribute: facilityaction: upsert- key: facilityaction: delete- key: syslog.priorityfrom_attribute: priorityaction: upsert- key: priorityaction: delete- key: syslog.proc_idfrom_attribute: proc_idaction: upsert- key: proc_idaction: delete- key: syslog.versionfrom_attribute: versionaction: upsert- key: versionaction: delete- key: syslog.appnamefrom_attribute: appnameaction: upsert- key: appnameaction: delete- key: messageaction: deleteexporters:otlphttp:endpoint: ${env:DT_ENDPOINT}headers:Authorization: "Api-Token ${env:DT_API_TOKEN}"service:pipelines:logs:receivers: [syslog/f5, syslog/host]processors: [attributes]exporters: [otlphttp]
Validate your settings to avoid any configuration issues.
For our configuration, we use the following components.
Under receivers
, we specify two instances of the syslog
receiver as active receiver components for our Collector instance.
The Syslog receiver supports a number of configuration parameters, which enable you to customize its behavior. For our example, we use the following:
tcp
—Specifies a TCP listener for the receiver and configures ports 54526 and 54527protocol
—Specifies the RFC 5424 implementation for our receiver (alternatively, RFC 3164 is also supported)operators
—Configures the operators we apply to each log entry. For our example, we use the add operator to add additional information.
field
—Specifies the name of value we are addingvalue
—Specifies the content of the value we are addingUnder processors
, we configure the attributes
processor to drop and adjust the indicated attributes in our OTLP request.
Under exporters
, we specify the default otlphttp
exporter and configure it with our Dynatrace API URL and the required authentication token.
For this purpose, we set the following two environment variables and reference them in the configuration values for endpoint
and Authorization
.
DT_ENDPOINT
contains the base URL of the Dynatrace API endpoint (for example, https://{your-environment-id}.live.dynatrace.com/api/v2/otlp
)DT_API_TOKEN
contains the API tokenUnder service
, we eventually assemble our receiver, processor, and exporter objects into a logs pipeline, which uses the receiver instances to obtain syslog data and ingest it into Dynatrace using OTLP.
Logs are ingested using the OpenTelemetry protocol (OTLP) via the Dynatrace OTLP API and are subject to the API's limits and restrictions. For more information see: