Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

in_process_exporter_metrics: Add documentation for process_exporter_metrics #1198

Merged
merged 18 commits into from
Dec 1, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions SUMMARY.md
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,7 @@
* [Node Exporter Metrics](pipeline/inputs/node-exporter-metrics.md)
* [Podman Metrics](pipeline/inputs/podman-metrics.md)
* [Process Log Based Metrics](pipeline/inputs/process.md)
* [Process Exporter Metrics](pipeline/inputs/process-exporter-metrics.md)
* [Prometheus Scrape Metrics](pipeline/inputs/prometheus-scrape-metrics.md)
* [Random](pipeline/inputs/random.md)
* [Serial Interface](pipeline/inputs/serial-interface.md)
Expand Down
84 changes: 84 additions & 0 deletions pipeline/inputs/process-exporter-metrics.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
---
description: >-
A plugin based on Process Exporter to collect process level of metrics of system
metrics
---

# Process Exporter Metrics

[Prometheus Node Exporter](https://github.com/prometheus/node_exporter) is a popular way to collect system level metrics from operating systems, such as CPU / Disk / Network / Process statistics. Fluent Bit 2.2 includes process exporter metrics plugin that builds off the Prometheus design to collect process level metrics without having to manage two separate processes or agents.
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved

The initial release of Process Exporter Metrics refers a process group level collector to collect metrics available from [the 3rd party implementation of Prometheus Process Exporter](https://github.com/ncabatoff/process-exporter) and we plan to expand them over time if needed.
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved

**Important note:** Metrics collected with Process Exporter Metrics flow through a separate pipeline from logs and current filters do not operate on top of metrics.
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved

This plugin is only supported on Linux based operating systems.
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved


## Configuration

| Key | Description | Default |
| ------------------------- | -------------------------------------------------------------------------------------- | --------- |
| scrape_interval | The rate at which metrics are collected from the host operating system | 5 seconds |
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
| path.procfs | The mount point used to collect process information and metrics | /proc/ |
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
| process\_include\_pattern | regex to determine which processes are included in the metrics produced by this plugin | It is applied for all process unless explicitly set. Default is `.+`. |
| process\_exclude\_pattern | regex to determine which units are excluded in the metrics produced by this plugin | It is not applied unless explicitly set. Default is `NULL`. |
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved

## Getting Started

### Simple Configuration File

In the following configuration file, the input plugin _process\_exporter\_metrics collects _metrics every 2 seconds and exposes them through our [Prometheus Exporter](../outputs/prometheus-exporter.md) output plugin on HTTP/TCP port 2021.

```
# Process Exporter Metrics + Prometheus Exporter
# -------------------------------------------
# The following example collect host metrics on Linux and expose
# them through a Prometheus HTTP end-point.
#
# After starting the service try it with:
#
# $ curl http://127.0.0.1:2021/metrics
#
[SERVICE]
flush 1
log_level info

[INPUT]
name process_exporter_metrics
tag process_metrics
scrape_interval 2

[OUTPUT]
name prometheus_exporter
match process_metrics
host 0.0.0.0
port 2021
```

You can test the expose of the metrics by using _curl:_
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved

```bash
curl http://127.0.0.1:2021/metrics
```

### Container to Collect Host Metrics

When deploying Fluent Bit in a container you will need to specify additional settings to ensure that Fluent Bit has access to the host operating system. The following docker command deploys Fluent Bit with specific mount path for ptocfs and settings enabled to ensure that Fluent Bit can collect from the host. These are then exposed over port 2021.
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved

```
docker run -ti -v /proc:/host/proc \
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
-v /sys:/host/sys \
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
-p 2021:2021 \
fluent/fluent-bit:2.2.0 \
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
/fluent-bit/bin/fluent-bit \
-i process_exporter_metrics -p path.procfs=/host/proc \
-o prometheus_exporter -p "add_label=host $HOSTNAME" \
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
-f 1
```

## Enhancement Requests

Our current plugin refers a sub-set of the available collectors in the 3rd party implementation of Prometheus Process Exporter, if you would like that we prioritize a specific metrics please open a Github issue by using the following template:\
cosmo0920 marked this conversation as resolved.
Show resolved Hide resolved
\
\- [in_process_exporter_metrics](https://github.com/fluent/fluent-bit/issues/new?assignees=\&labels=\&template=feature_request.md\&title=in_process_exporter_metrics:%20add%20ABC%20collector)