Skip to content

code-tool/inventor

Repository files navigation

inventor

Prometheus HTTP SD implementation

Description

The Inventor is a Prometheus HTTP SD Server allows users to dynamcially add or remove prometheus targets and labels and expose it to a Prometheus HTTP SD job.

Usage

Running the server:

cd src
go run main.go

Installing with Helm

helm repo add inventor https://code-tool.github.io/inventor/

Registering new target:

curl -X PUT -H "x-api-token: secret" http://127.0.0.1:9101/target \
-d '{"static_config": {"targets": ["10.0.10.2:9100",], "labels": {"__meta_datacenter": "dc-01", "__meta_prometheus_job": "node"}, "target_group": "mygroup"}}'

More examples: ./test/end-to-end

Prometheus SD config example

scrape_configs:
  - job_name: http_sd
    http_sd_configs:
      - url: http://127.0.0.1:9101/discover
        # if SD_TOKEN env variable is set
        headers:
          - "x-sd-token: REDACTED"

Prometheus SD config with groups example

scrape_configs:
  - job_name: http_sd_mygroup
    http_sd_configs:
      - url: http://127.0.0.1:9101/group?name=mygroup
        # if SD_TOKEN env variable is set
        headers:
          - "x-sd-token: REDACTED"

Configuration Environmet Valiables

  • REDIS_ADDR: redis server addres to store metrics and targets
  • REDIS_PORT: redis server port
  • REDIS_DBNO: redis server keyspace
  • TTL_SECONDS: ttl for storing target, default is 6h (21600 seconds)
  • API_TOKEN: API token for manipulating targets
  • SD_TOKEN: Options token for Prometheus HTTP SD, is empty by default and not validating (header x-sd-token)

Custom discovered labels

  • __meta_inventor_sd_module: contains element of modules: [], useful for relabeling to add __param_module

Data file with modules for exporter_exporter example:

{
  "static_config": {
  "targets": ["host.local:9999"],
  "labels": {
    "__inventor_sd_metrics_path": "/proxy",
    "__inventor_sd_job": "inventor-exporter-proxy",
    "datacenter": "the-dc"
  },
  "modules": ["node_exporter","ipmi_exporter"],
  "target_group": "inventor-default"
  }
}

Prometheus SD config with relabel_config example

scrape_configs:
  - job_name: http_sd_mygroup
    http_sd_configs:
      - url: http://127.0.0.1:9101/discover
        # if SD_TOKEN env variable is set
        headers:
          - "x-sd-token: REDACTED"
    relabel_configs:
      # discovered label
      - source_labels: [ __meta_inventor_sd_module ]
        target_label: __param_module
      # labels from data file
      - source_labels: [ __inventor_sd_metrics_path ]
        target_label: __metrics_path__
      - source_labels: [ __inventor_sd_job ]
        target_label: job

This produces scrape jobs with module parameter:

http://host.local:9999/proxy&module=node_exporter
http://host.local:9999/proxy&module=ipmi_exporter

API Methods

  • GET /discover
    • Returning the list of targets in Prometheus HTTP SD format
  • GET /group
    • Returning targets by group name /group?name=mygroup
  • PUT /target
    • Adds the new target
  • GET /target
    • Returning target by ID
  • DELETE /target
    • Removing target by ID
  • GET /metrics
    • Metrics in prometheus format
  • GET /healthcheck
    • Health Check for kubernetes deployments

Build Docker image

docker build -t ghcr.io/code-tool/inventor/inventor:$(cat VERSION.txt) --build-arg BUILD_VERSION=$(cat VERSION.txt) -f docker/Dockerfile .

pulling image:

ghcr.io/code-tool/inventor/inventor:0.0.3

License

Covered under the MIT license.

About

Prometheus HTTP SD implementation

Resources

License

Stars

Watchers

Forks

Packages

No packages published