Prometheus HTTP SD implementation
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.
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"
REDIS_ADDR: redis server addres to store metrics and targetsREDIS_PORT: redis server portREDIS_DBNO: redis server keyspaceTTL_SECONDS: ttl for storing target, default is 6h (21600 seconds)API_TOKEN: API token for manipulating targetsSD_TOKEN: Options token for Prometheus HTTP SD, is empty by default and not validating (headerx-sd-token)
__meta_inventor_sd_module: contains element ofmodules: [], 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: jobThis produces scrape jobs with module parameter:
http://host.local:9999/proxy&module=node_exporter
http://host.local:9999/proxy&module=ipmi_exporter
- GET /discover
- Returning the list of targets in Prometheus HTTP SD format
- GET /group
- Returning targets by group name
/group?name=mygroup
- Returning targets by group name
- 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
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.3Covered under the MIT license.