Prometheus: Difference between revisions
Linked to Grafana |
m Fixed link to loki |
||
| (2 intermediate revisions by one other user not shown) | |||
| Line 1: | Line 1: | ||
[https://prometheus.io/ Prometheus] is | '''[https://prometheus.io/ Prometheus]''' is an open-source event monitoring and alerting application. It records metrics in a time series database built by pulling (also known as ''scraping'') metrics from different services, with flexible queries and real-time alerting. | ||
{{infobox application | |||
|name=Prometheus | |||
|image=Prometheus software logo.svg | |||
|type=Metrics aggregation system | |||
|status=Active | |||
|license=Apache License 2.0 | |||
|programmingLanguage=Go | |||
|github=prometheus/prometheus | |||
|documentation=https://prometheus.io/docs/introduction/overview/ | |||
}} | |||
== | == Prometheus exporters == | ||
== | Prometheus works by scraping from HTTP endpoints, which are often provided by '''Prometheus exporters'''. | ||
=== <code>node_exporter</code> === | |||
Below is an example of [https://prometheus.io/docs/guides/node-exporter/ prometheus node_exporter] with additional collectors enabled. [https://nixos.org/manual/nixos/stable/#module-services-prometheus-exporters <code>node_exporter</code> is documented in the NixOS manual]. | |||
{{file|/etc/nixos/configuration.nix|nix|<nowiki> | |||
{ config, pkgs, ... }: | { config, pkgs, ... }: | ||
{ | { | ||
| Line 20: | Line 32: | ||
}; | }; | ||
} | } | ||
</ | </nowiki>}} | ||
== | |||
The Prometheus service daemon can be enabled and configured by further options.< | == Usage == | ||
services.prometheus.enable = true; | |||
</ | The Prometheus service daemon can be enabled and configured by further options. | ||
{{file|/etc/nixos/configuration.nix|nix|<nowiki> | |||
{ | |||
services.prometheus.enable = true; | |||
} | |||
</nowiki>}} | |||
Another example: | |||
{{file|/etc/nixos/configuration.nix|nix|<nowiki> | |||
{ config, pkgs, ... }: | { config, pkgs, ... }: | ||
{ | { | ||
| Line 34: | Line 55: | ||
globalConfig.scrape_interval = "10s"; # "1m" | globalConfig.scrape_interval = "10s"; # "1m" | ||
scrapeConfigs = [ | scrapeConfigs = [ | ||
{ | |||
job_name = "node"; | |||
static_configs = [{ | |||
targets = [ "localhost:${toString config.services.prometheus.exporters.node.port}" ]; | |||
}]; | |||
} | |||
]; | ]; | ||
}; | }; | ||
} | } | ||
</ | </nowiki>}} | ||
== See also == | |||
* [[Grafana]], the dashboarding tool often used with Prometheus. | |||
* [[Grafana Loki|Loki]], the equivalent of Prometheus for logs. | |||
[[Category:Server]] | [[Category:Server]] | ||
[[Category:NixOS Manual]] | [[Category:NixOS Manual]] | ||