#open-telemetry #metrics #cpu #cpu-memory #disk #networking #export

opentelemetry-system-metrics

System metric export through Opentelemetry

8 releases

0.1.8 Mar 15, 2024
0.1.7 Mar 11, 2024
0.1.6 Nov 20, 2023
0.1.3 Oct 19, 2023
0.1.1 Jun 24, 2022

#766 in Network programming

Download history 27/week @ 2023-12-30 384/week @ 2024-01-06 34/week @ 2024-01-13 57/week @ 2024-01-20 43/week @ 2024-01-27 3/week @ 2024-02-03 181/week @ 2024-02-10 86/week @ 2024-02-17 177/week @ 2024-02-24 190/week @ 2024-03-02 820/week @ 2024-03-09 1131/week @ 2024-03-16 390/week @ 2024-03-23 619/week @ 2024-03-30 623/week @ 2024-04-06

3,028 downloads per month
Used in 2 crates (via dora-metrics)

Apache-2.0

20KB
149 lines

opentelemetry-system-metrics

This is my awesome crate enabling process level system metrics using opentelemetry.

Current metrics observed are:

  • CPU
  • Memory
  • Disk
  • Network
  • GPU Memory

Getting started

cargo add opentelemetry_system_metrics
use opentelemetry::global;
use opentelemetry_system_metrics::init_process_observer;

let meter = global::meter("process-meter");
init_process_observer(meter);

To get started with InfluxDB, you should create an account at InfluxDB Cloud, create a new telegraf opentelemetry exporter.

  • Ex:
export INFLUX_TOKEN=<PROVIDED TOKEN>
telegraf --config <PROVIDED LINK>
cargo run --example otlp-tokio-metrics

lib.rs:

This is my awesome crate Enabling system metrics from process to be observed using opentelemetry. Current metrics observed are:

  • CPU
  • Memory
  • Disk
  • Network

Getting started

use opentelemetry::global;
use opentelemetry_system_metrics::init_process_observer;

let meter = global::meter("process-meter");
init_process_observer(meter);

Dependencies

~5MB
~93K SLoC