This project sets up a monitoring system using Prometheus, Grafana, and Node Exporter for visualizing server and application metrics. Additionally, custom SSH scripts are included to collect metrics from remote servers and feed them into Prometheus.
- Docker Compose: Deploy Prometheus, Grafana, and Node Exporter with a single command.
- Custom Metrics Collection: Scripts to collect metrics from remote servers using SSH.
- NGINX Reverse Proxy: Configurations for secure access to Grafana and Prometheus.
- Textfile Collector: Prometheus-compatible
.prom
files for custom metrics.
├── docker-compose.yml # Docker Compose configuration file
├── grafana # Grafana configuration directory
│ └── provisioning # Provision Grafana Config
│ ├── dashboards # Imported Grafana dashboards
│ │ ├── dashboard-1.json # Grafana dashboard template
│ │ ├── dashboard.yml # Grafana dashboard config
│ │ └── HostingServers.json # Grafana dashboard template
│ ├── datasources # Datasource configuration
│ │ └── prometheus.yml # Prometheus as a data source
│ └── grafana.ini # Grafana configuration
├── nginx # NGINX configuration directory
│ ├── grafana.conf # NGINX config for Grafana
│ └── prometheus.conf # NGINX config for Prometheus
├── prometheus # Prometheus configuration directory
│ ├── data # Prometheus data (persistent volume)
│ └── prometheus.yml # Prometheus scrape configurations
├── README.md # Project documentation
├── Scripts # Custom scripts for metric collection
│ └── metric_collector_with_unique_server_id.sh
└── textfile-collector
Prerequisites
Docker and Docker Compose installed.
SSH access to the servers you want to monitor.
NGINX installed for reverse proxy.
Deployment
Clone the repository:
git clone https://github.com/sirmosi/monitor_nginx_grafana_prometheus.git
cd monitor_nginx_grafana_prometheus
Start the monitoring stack:
docker-compose up -d
Verify services:
Grafana: http://grafana.example.com
Prometheus: http://prometheus.example.com
Adding Prometheus Data Source
Open Grafana: http://grafana.example.com
Add Prometheus as a data source:
URL: http://prometheus:9090
Import Dashboards
Go to Dashboards → Import.
Upload the JSON files from grafana/provisioning/dashboards/.
Grafana Configuration (nginx/grafana.conf)
server {
listen 80;
server_name grafana.example.com;
location / {
proxy_pass http://localhost:3000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
Prometheus Configuration (nginx/prometheus.conf)
server {
listen 80;
server_name prometheus.example.com;
location / {
proxy_pass http://localhost:9090;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
SSH Script (Scripts/Collector.sh)
This script collects metrics from remote servers via SSH and saves them in Prometheus-compatible .prom files. Usage
Edit the SERVERS variable in the script to include your servers.
Schedule the script to run periodically via cron:
crontab -e
* * * * * /path/to/Scripts/Collector.sh
Example Script
#!/bin/bash
SERVERS=("server2" "server4")
USER="ssh-user"
OUTPUT_DIR="./textfile-collector"
collect_metrics() {
SERVER=$1
CPU=$(ssh "$USER@$SERVER" "top -bn1 | grep 'Cpu(s)' | awk '{print 100 - \$8}'")
cat <<EOF > "$OUTPUT_DIR/metrics_$SERVER.prom"
# HELP cpu_usage_percent CPU usage percentage.
# TYPE cpu_usage_percent gauge
cpu_usage_percent{host="$SERVER"} $CPU
EOF
}
for SERVER in "${SERVERS[@]}"; do
collect_metrics "$SERVER"
done
We welcome suggestions, improvements, and contributions to make this project even better! Here are some ideas:
Enhance the SSH script to collect more metrics (e.g., memory, disk, network usage).
Optimize NGINX configurations for better performance and security.
Create additional Grafana dashboards for specific use cases.
If you have any questions, suggestions, or want to collaborate, feel free to reach out: