#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

#759 in Network programming

Download history 71/week @ 2024-01-25 7/week @ 2024-02-01 169/week @ 2024-02-08 82/week @ 2024-02-15 135/week @ 2024-02-22 118/week @ 2024-02-29 472/week @ 2024-03-07 1375/week @ 2024-03-14 494/week @ 2024-03-21 468/week @ 2024-03-28 810/week @ 2024-04-04 698/week @ 2024-04-11 532/week @ 2024-04-18 676/week @ 2024-04-25 1317/week @ 2024-05-02 801/week @ 2024-05-09

3,445 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
~95K SLoC