Files
the_information_nexus/tech_docs/prometheus-docker.md

132 lines
3.3 KiB
Markdown

# Setting Up Prometheus with Docker Compose
This guide provides a step-by-step approach to set up Prometheus with Docker Compose, including troubleshooting common issues.
## Step 1: Clean Up Docker Environment
First, ensure all existing containers and networks are removed to start fresh:
```bash
docker-compose down -v
docker system prune -f
docker volume prune -f
```
## Step 2: Verify and Correct Configuration Files
Ensure the `docker-compose.yml` and `prometheus.yml` files are correctly formatted and contain no errors.
### docker-compose.yml
```yaml
version: '3.8'
services:
prometheus:
image: prom/prometheus:latest
container_name: prometheus
ports:
- "9090:9090"
volumes:
- ./prometheus.yml:/etc/prometheus/prometheus.yml
- ./alert.rules:/etc/prometheus/alert.rules
networks:
- monitoring
node_exporter:
image: prom/node-exporter:latest
container_name: node_exporter
networks:
- monitoring
networks:
monitoring:
driver: bridge
```
### prometheus.yml
```yaml
global:
scrape_interval: 15s
rule_files:
- /etc/prometheus/alert.rules
scrape_configs:
- job_name: 'prometheus'
static_configs:
- targets: ['localhost:9090']
- job_name: 'node_exporter'
static_configs:
- targets: ['node_exporter:9100']
```
### alert.rules
Create a file named `alert.rules` if it doesn't exist:
```yaml
groups:
- name: example
rules:
- alert: InstanceDown
expr: up == 0
for: 5m
labels:
severity: critical
annotations:
summary: "Instance {{ $labels.instance }} down"
description: "{{ $labels.instance }} of job {{ $labels.job }} has been down for more than 5 minutes."
```
## Step 3: Restart Docker Services
Restart the Docker services to apply the changes:
```bash
docker-compose up --build -d
```
## Step 4: Verify Configuration and Connectivity
Check the container logs to ensure Prometheus started correctly:
```bash
docker-compose logs prometheus
```
## Step 5: Test Prometheus API
Test the Prometheus API to ensure it is working correctly.
### Check Prometheus Targets
```bash
curl http://localhost:9090/api/v1/targets
```
### Query Node Exporter Status
```bash
curl 'http://localhost:9090/api/v1/query?query=up{job="node_exporter"}'
```
If the above command returns a parsing error, use the URL-encoded query:
```bash
curl 'http://localhost:9090/api/v1/query?query=up%7Bjob%3D%22node_exporter%22%7D'
```
## Summary
By ensuring the configuration files are correctly formatted and starting fresh with the Docker environment, you should be able to resolve issues and get Prometheus running smoothly. If you encounter any further issues, check the container logs and configuration for errors.
### Additional Troubleshooting Tips
- **Ensure Prometheus is Running**: Verify that Prometheus is running by checking the Docker container status with `docker ps`.
- **Check Network Configuration**: Ensure the Docker network is correctly set up and that containers are connected to the `monitoring` network.
- **Access Prometheus Web UI**: Navigate to `http://localhost:9090` in your web browser to access the Prometheus web interface and verify the targets and query metrics.
This document should serve as a comprehensive reference for setting up and troubleshooting Prometheus with Docker Compose.