Troubleshooting
This document contains common troubleshooting scenarios and frequently asked questions about the Sumo Logic OpenTelemetry Collector.
About the Sumo Logic OTel Collectorβ
What's the difference between OpenTelemetry and the Sumo Logic Distribution for OpenTelemetry?β
OpenTelemetry is a state-of-the-art open standard for collecting all kinds of observability data. Using a single common standard, it can flexibly collect logs, metrics, and tracing data. It is open source and freely available to download and hack on. It comes out of the box with support for the most popular integrations and makes it very easy to implement new ones if your use case isnβt already covered (it probably is!).
The Sumo Logic Distribution for OpenTelemetry is a custom build of the OpenTelemetry collector that's optimized for interacting with Sumo Logicβs API. It supports everything the standard collector does, but has some additional extensions for Sumo Logic.
How is the Sumo Logic OpenTelemetry Collector different from the Installed Collector? Which one should I use?β
You can compare the OpenTelemetry and Installed Collector here to decide which one is right for you.
What OS versions does the Sumo Logic OpenTelemetry Collector support?β
The following operating systems are officially supported:
Operating System | Versions Supported |
---|---|
Linux | RHEL (7-9), Debian (9-11), Ubuntu (18-22), SUSE (ES12, ES15), Amazon Linux 2, CentOS (7, 8) |
Windows | Windows 10 and up, Windows Server 2016 and up |
macOS | macOS 10.X and up |
Although our OpenTelemetry Collector may work on other OS platforms and versions, those are not officially tested by Sumo Logic, so we cannot guarantee support.
How does an OpenTelemetry Collector send information to the Sumo Logic service?β
The OpenTelemetry Collector uses the OTLP protocol to send data to the Sumo Logic service.
How frequently does OpenTelemetry Collector flush data to the Sumo Logic backend?β
By default, the OpenTelemetry Collector will flush data either every second or every time it accumulates 1024 data points, whichever comes first. These default values can be modified by adjusting the configuration settings of the collector.
What is the size of the Sumo Logic OpenTelemetry Collector cache? Under what conditions does the Collector cache the data? How does caching work for the OpenTelemetry Collector?β
The default cache size for the Sumo Logic OpenTelemetry Collector is 5000 batches, each containing up to 1024 data points. The actual on-disk size of the cache depends on the size of the data points, but it's typically around 700 bytes per data point.
The collector caches data when itβs unable to send it to the Sumo backend at the rate the data it is being produced. This can be due to various reasons, such as network issues or temporary unavailability of Sumo, and others.
Does the Sumo Logic backend know when a OpenTelemetry Collector is down? How does that work?β
The collector sends a heartbeat message every 15 seconds (by default).
Does the OpenTelemetry Collector get throttled? Under what circumstances does this happen?β
The behavior is the same as for any other collection method.
Collector connection failureβ
How do I provide a proxy setting for the Sumo Logic OpenTelemetry Collector to connect to the Sumo Logic backend?β
If your Collector fails to connect to Sumo Logic, you may need to configure a proxy setting for the Sumo Logic OpenTelemetry Collector so that it can connect to the Sumo Logic backend. The information how to install the proxy has been provided on the Install Collector page for the specific platform.
On macOS, does the Sumo Logic OpenTelemetry Collector stop sending data after some time?β
Because the OpenTelemetry Collector is connected to the terminal, it will stop reporting data when you log off, close the terminal, or put the computer to sleep.
I am seeing some errors related to Sumo Logic OpenTelemetry Collector stating that Unable to get a heartbeat
. Does this mean my collector is not collecting any data?β
This means the collector is having trouble connecting to the Sumo Logic backend.
While data should still be collected and shipped to Sumo, the collector may appear as down in the user interface. In general, these types of errors can occur during normal operations. They can be safely ignored as long as they are not persistent.
Collector installation errorsβ
Accessing the collector's logsβ
- Systemd
- Standalone Binary
- Windows
On systems with systemd, the logs are available in journald:
journalctl --unit otelcol-sumo
On systems without systemd, the logs are available in the console output of the running process.
On Windows, the logs are available in event viewer, or they can be listed using PowerShell:
Get-EventLog -LogName Application -Newest 100 -Source OtelcolSumo | Select-Object @{Name='TimeGenerated'; Expression={($_.TimeGenerated).ToString("yyyy-MM-dd HH:mm:ss")}}, ReplacementStrings | Format-Table -Wrap
Sending the collector's logs to Sumo Logicβ
If desired, you can change the collector's logging level and have the collector's logs be sent to Sumo Logic for analysis and troubleshooting. To do this, you'll need add the following to your collector's configuration (located in /etc/otelcol-sumo/conf.d
):
- Create a new logging file in the
/var/log
directory. For example:/var/log/otelcol.log
. Make sure this file has read and write permissions for the collector. - Add the
telemetry
service to the collector config, and set the logginglevel
(default = INFO) andoutput_paths
parameters accordingly. See example config below. - Add a fileog receiver to read from the output_paths that you've specified previously (i.e.,
/var/log/otelcol.log
). This is the where the collectors log files are written. - Make sure that you update your service pipelines to include this receiver so you can send them to Sumo Logic.
See the example configuration below, which sets the log level to DEBUG
, the log output path to /var/log/otelcol.log
, and has a filelog receiver to read the logs:
receivers:
filelog/collector_files:
include:
- /var/log/otelcol.log
include_file_name: false
include_file_path_resolved: true
operators:
- type: move
from: attributes["log.file.path_resolved"]
to: resource["_sourceName"]
service:
telemetry:
logs:
level: DEBUG
output_paths: /var/log/otelcol.log
pipelines:
logs:
receivers:
- filelog/collector_files
exporters:
- sumologic
Doing this will allow you to search the collectors logs in Sumo Logic by performing a log search similar to the following:
_collector="<collector name>" and _sourceName="/var/log/otelcol.log"
Accessing the collector's metricsβ
By default, the collector's own metrics are available in Prometheus format at http://localhost:8888/metrics
.
To access them, use a tool like curl
or just open the URL in a browser running on the same host as the collector.
curl http://localhost:8888/metrics
To modify the port, use the service.telemetry.metrics.address
property:
service:
telemetry:
metrics:
address: ":8889"
Sending the collector's metrics to Sumo Logicβ
If desired, you can send the collector's metrics to Sumo Logic for analysis and troubleshooting. To do this, you need add the following to your collector's configuration (located in /etc/otelcol-sumo/conf.d
):
- Add the
telemetry
service to the collector config, and set the metriclevel
(default = basic) andaddress
parameters accordingly. See example config below. - Add a prometheus receiver to scrape the collectors metrics.
- Make sure that you update your service pipelines to include this receiver so you can send them to Sumo Logic.
See the example configuration below, which sets the metrics level to detailed
and has a prometheus receiver to scrape them:
receivers:
prometheus:
trim_metric_suffixes: true
use_start_time_metric: true
start_time_metric_regex: .*
config:
scrape_configs:
- job_name: 'otel-collector'
scrape_interval: 5s
static_configs:
- targets: ['<internal IP of instance>:8888']
service:
telemetry:
metrics:
level: detailed
address: 0.0.0.0:8888
pipelines:
metrics:
receivers:
- prometheus
exporters:
- sumologic
Doing this will allow you to search the collectors metrics in Sumo Logic by performing a metrics search similar to the following:
_collector="<collector name>" _sourcename="otc metric input"
You can find more information on customizing the collector's telemetry in the OpenTelemetry Documentation Configuration section.
Known Issuesβ
Changes to collector properties are not appliedβ
After running the collector for the first time, changes to collector properties (e.g., collector description, category, fields) are not applied.
To work around this, you need to delete the existing collector registration and register the collector again. To do this, you need to do two things:
- Delete the local collector registration file in
~/.sumologic-otel-collector/
and wait for 10 minutes for the collector to get offline. - Remove the collector in Sumo Logic UI.
- Sign in to Sumo Logic platform.
- Classic UI. In the main Sumo Logic menu, select Manage Data > Collection > Collection.
New UI. In the Sumo Logic top menu select Configuration, and then under Data Collection select Collection. You can also click the Go To... menu at the top of the screen and select Collection. - Find your collector.
After that, the collector will register on the next run.
The collector will fail to start if you delete the collector in the UI but do not delete the local registration file. Refer to Collector fails to start when deleted from UI.
On the other hand, if you only delete the local registration file and do not delete the collector in the UI, a new collector will be created with current timestamp as a suffix, to prevent overwriting the existing collector.
Collector fails to start when deleted from UIβ
After successful registration of collector, if you delete the collector in Sumo Logic UI, the collector will fail to start on next run. The error message is similar to the below:
2024-02-21T10:59:54.665+0100 info extensions/extensions.go:37 Extension is starting... {"kind": "extension", "name": "sumologic"}
2024-02-21T10:59:54.666+0100 info credentials/credentialsstore_localfs.go:147 Collector registration credentials retrieved from local fs {"kind": "extension", "name": "sumologic", "path": "/var/lib/otelcol-sumo/credentials/f1e98079b6ff1105a0d1ba513531ef57364b326da18ccdea63da4c2cb811790a"}
2024-02-21T10:59:54.666+0100 info sumologicextension@v0.91.0-sumo-0/extension.go:238 Validating collector credentials... {"kind": "extension", "name": "sumologic", "collector_credential_id": "AiN2lZaDWkWSWqHkBHy8", "collector_id": "00005AF3107B06F2"}
2024-02-21T10:59:54.927+0100 info sumologicextension@v0.91.0-sumo-0/extension.go:339 Found stored credentials, skipping registration {"kind": "extension", "name": "sumologic", "collector_name": "<your-collector-name>"}
2024-02-21T10:59:55.068+0100 info sumologicextension@v0.91.0-sumo-0/extension.go:816 Updating collector metadata {"kind": "extension", "name": "sumologic", "collector_name": "<your-collector-name>", "collector_id": "00005AF3107B06F2", "URL": "https://open-collectors.de.sumologic.com/api/v1/otCollectors/metadata", "body": "{\"hostDetails\":{\"name\":\"<your-collector-name>\",\"osName\":\"darwin\",\"osVersion\":\"14.3.1\",\"environment\":\"\"},\"collectorDetails\":{\"runningVersion\":\"v0.94.0-sumo-2\"},\"networkDetails\":{\"hostIpAddress\":\"192.168.0.133\"},\"tagDetails\":{\"deployment.environment\":\"default\",\"host.group\":\"default\",\"sumo.disco.enabled\":\"true\"}}\n"}
2024-02-21T10:59:55.280+0100 warn sumologicextension@v0.91.0-sumo-0/extension.go:836 Metadata API error response {"kind": "extension", "name": "sumologic", "collector_name": "<your-collector-name>", "collector_id": "00005AF3107B06F2", "status": 404, "body": ""}
2024-02-21T10:59:55.280+0100 warn sumologicextension@v0.91.0-sumo-0/extension.go:864 collector metadata update failed: collector metadata request failed: API error (status code: 404): {"kind": "extension", "name": "sumologic", "collector_name": "<your-collector-name>", "collector_id": "00005AF3107B06F2"}
To work around this, delete the local collector registration file at ~/.sumologic-otel-collector/
. The collector will re-register on next run.
Enabling clobber
property re-registers collector on every restartβ
If you set the extensions.sumologic.clobber
property to true
, a new collector registration that replaces the previously existing registration will be created on every run of the collector.
This affects the _collectorId
attribute, which is different for every new collector registration.
To prevent this, remove the extensions.sumologic.clobber
property or set it to false
.
Cannot start reading file logs from specific point in timeβ
The Filelog receiver currently supports only two modes of reading local files:
start_at: beginning
: Ingest the whole file from the beginning, orstart_at: end
: Only ingest newly added lines.
The start_at
property is common to all the files read by the receiver - it cannot be set to end
for some files and to beginning
for other files. Note that this can be worked around by creating two separate Filelog receivers, one reading from the beginning and one reading from the end.
The other problem is that it is not currently possible for Filelog receiver to start reading files at a specific point, or only read files created or modified after a specific point in time.
There is currently no workaround for this.