Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ruanbekker/docker-monitoring-stack-gpnc
Grafana Prometheus Node-Exporter cAdvisor - Docker Monitoring Stack
https://github.com/ruanbekker/docker-monitoring-stack-gpnc
alertmanager cadvisor docker docker-compose grafana grafana-dashboard loki monitoring node-exporter prometheus prometheus-metrics
Last synced: 3 days ago
JSON representation
Grafana Prometheus Node-Exporter cAdvisor - Docker Monitoring Stack
- Host: GitHub
- URL: https://github.com/ruanbekker/docker-monitoring-stack-gpnc
- Owner: ruanbekker
- License: mit
- Created: 2022-03-31T11:54:41.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-04T08:57:30.000Z (4 months ago)
- Last Synced: 2025-01-12T07:06:48.979Z (10 days ago)
- Topics: alertmanager, cadvisor, docker, docker-compose, grafana, grafana-dashboard, loki, monitoring, node-exporter, prometheus, prometheus-metrics
- Language: Makefile
- Homepage:
- Size: 2.65 MB
- Stars: 159
- Watchers: 6
- Forks: 39
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# docker-monitoring-stack-gpnc
Grafana Prometheus Node-Exporter cAdvisor Loki - Docker Monitoring Stack## About
Get your monitoring stack up and running with one command using a Docker Compose stack featuring:
- **[Grafana](https://github.com/grafana/grafana)**: Dashboarding.
- **[Prometheus](https://github.com/prometheus/prometheus)**: Timeseries database for metrics.
- **[Node-Exporter](https://github.com/prometheus/node_exporter)**: Node metrics.
- **[cAdvisor](https://github.com/google/cadvisor)**: Container metrics.
- **[Alertmanager](https://github.com/prometheus/alertmanager)**: Alerting system.
- **[Uncomplicated Alert Receiver](https://github.com/jamesread/uncomplicated-alert-receiver)**: UI with Received Alerts.
- **[Loki](https://github.com/grafana/loki)**: Logs (including explore-logs).## Makefile
[Note](https://docs.docker.com/compose/install/linux/): Due to `docker-compose` and the `compose` plugin, you might have one of the two installed. I have a `Makefile` that will detect which on you have installed.
You can list the targets using `make`.
## Boot
Boot the stack with docker compose (or `make up`):
```bash
docker-compose up -d
```Ensure all containers are running:
```bash
docker-compose ps
```The output should looke like this:
```bash
Name Command State Ports
-----------------------------------------------------------------------------------------------------
cadvisor /usr/bin/cadvisor -logtostderr Up (healthy) 8080/tcp
grafana /run.sh Up 0.0.0.0:3000->3000/tcp
node-exporter /bin/node_exporter --path. ... Up 9100/tcp
prometheus /bin/prometheus --config.f ... Up 0.0.0.0:9090->9090/tcp
alertmanager /bin/alertmanager --config ... Up 0.0.0.0:9093->9093/tcp
loki /usr/bin/loki -conf ... Up 0.0.0.0:3100->3100/tcp
promtail /usr/bin/promtail ... Up
uncomplicated-alert-receiver /app/uar Up 0.0.0.0:9094->8080/tcp
```## Access Grafana
Access grafana on [Grafana Home](http://localhost:3000/?orgId=1) (or `make open`) and you should see the three dashboards that was provisioned:
![](./assets/grafana-home.png)
Once you select the **Node Metrics** dashboard, it should look something like this:
![](./assets/grafana-dashboard.png)
When you select ["Alerting" and "Alert rules"](http://localhost:3000/alerting/list) you will find the recording and alerting rules:
![](./assets/grafana-alerting-home.png)
We can expand the alerting rules:
![](./assets/grafana-alerting-rules.png)
And then we can view more detail on a alert rule:
![](./assets/grafana-alerting-detail.png)
When we see one of our alerts are in an alert state:
![](./assets/grafana-alert-state.png)
We will see them be displayed in Uncomplicated Alert Receiver:
![](./assets/uar-alert-view.png)
And for our container metrics we can access the **Container Metrics** dashboard:
![](./assets/grafana-container-metrics.png)
Then for our last dashboard, the **Container Log Search**, by default the metric panel will be collapsed, but to expand it for visibility it will look like this:
![](./assets/grafana-logs-search-dashboard.png)
And we can also view our **Container Logs** in the explore section:
![](./assets/grafana-logs-view.png)
For discovering the **Logs** we can navigate to the Explore / Logs view:
![](./assets/grafana-explore-logs.png)
## Endpoints
The following endpoints are available:
| Container | Internal Endpoint | External Endpoint |
| ---------------------------- | ----------------------------------------- |---------------------- |
| Grafana | http://grafana:3000 | http://localhost:3000 |
| Prometheus | http://prometheus:9090 | http://localhost:9090 |
| Node-Exporter | http://node-exporter:9100 | http://localhost:9100 |
| cAdvisor | http://cadvisor:8080 | N/A |
| Alertmanager | http://alertmanager:9093 | http://localhost:9093 |
| Uncomplicated Alert Receiver | http://uncomplicated-alert-receiver:9094 | http://localhost:9094 |
| Loki | http://loki:3100 | http://localhost:3100 |## Cleanup
To remove the containers using docker compose (or `make clean`):
```bash
docker-compose down
```## Stargazers over time
[![Stargazers over time](https://starchart.cc/ruanbekker/docker-monitoring-stack-gpnc.svg)](https://starchart.cc/ruanbekker/docker-monitoring-stack-gpnc)
## Resources
Heavily inspired from [this exporter guide](https://grafana.com/oss/prometheus/exporters/node-exporter/)