Skip to content

Latest commit

 

History

History
74 lines (53 loc) · 1.51 KB

README.md

File metadata and controls

74 lines (53 loc) · 1.51 KB

Microeye

A simple custom metrics storage and visualization tool.

Microeye

To run with basic auth use the following command

docker run -p 3000:3000 -e MICROEYE_ADMIN_PASSWORD=my_super_secret_password ierehon1905/microeye:latest

or the following to disable auth run

docker run -p 3000:3000 -e MICROEYE_DISABLE_AUTH=true ierehon1905/microeye:latest

Open the browser to see ui.

To push metrics run

curl -X POST -H "Content-Type: application/json" -d '{"name":"cpu","labels":{"a":"b"},"value":1}' http://localhost:3000/api/metrics/push

or to push multiple metrics

curl -X POST -H "Content-Type: application/json" -d '{"metrics":[{"name":"test","labels":{"label":"value"},"values":[1,2,3],"timestampsSec":[1705592323,1705592353,1705592423]}]}' http://localhost:3000/api/metrics/push-many

or use example pushers from ./pusher directory.

To push metrics from js use or make your own pusher

import axios from "axios";

class Pusher {
  constructor(host) {
    this.host = host;
  }

  async pushMetric(name, value, labels) {
    await axios.post(`${this.host}/api/metrics/push`, {
      name,
      value,
      labels,
    });
  }
}

export default Pusher;

Docker compose

services:
  # ...
  monitoring:
    image: ierehon1905/microeye:latest
    ports:
      - "3000:3000"
    volumes:
      - monitoring_data:/var/lib/postgresql/data

volumes:
  # ...
  monitoring_data:

And then use http://monitoring:3000 as host to push metrics.