From 611e9285a634a5b28606a87f7fe64862ae55b6e4 Mon Sep 17 00:00:00 2001 From: Sergen Uysal <0xsergen@gmail.com> Date: Thu, 26 Sep 2024 19:36:06 +0300 Subject: [PATCH] console API grafana dashboard --- console-api/grafana-dashboard/README.md | 35 ++ .../grafana-dashboard/docker-compose.yaml | 23 + .../dashboards/QuickNode Console API.json | 584 ++++++++++++++++++ .../grafana/provisioning/dashboards/main.yaml | 12 + .../datasources/prometheus-source.yaml | 9 + .../prometheus/prometheus.yaml | 12 + 6 files changed, 675 insertions(+) create mode 100644 console-api/grafana-dashboard/README.md create mode 100644 console-api/grafana-dashboard/docker-compose.yaml create mode 100644 console-api/grafana-dashboard/grafana/dashboards/QuickNode Console API.json create mode 100755 console-api/grafana-dashboard/grafana/provisioning/dashboards/main.yaml create mode 100644 console-api/grafana-dashboard/grafana/provisioning/datasources/prometheus-source.yaml create mode 100644 console-api/grafana-dashboard/prometheus/prometheus.yaml diff --git a/console-api/grafana-dashboard/README.md b/console-api/grafana-dashboard/README.md new file mode 100644 index 0000000..ca02b6b --- /dev/null +++ b/console-api/grafana-dashboard/README.md @@ -0,0 +1,35 @@ +# QuickNode Grafana Dashboard Example + +This folder contains all the necessary configuration files to set up a Grafana dashboard for monitoring your QuickNode RPC infrastructure using Prometheus. This example is part of the [How to Build a Grafana Dashboard to Monitor Your RPC Infrastructure](https://www.quicknode.com/guides/quicknode-products/console-api/how-to-build-a-grafana-dashboard-to-monitor-your-rpc-infrastructure) guide, which walks you through setting up a real-time monitoring system. + +## Prerequisites + +- **Docker Desktop**: Ensure you have **[Docker Desktop](https://www.docker.com/products/docker-desktop/)** installed and running. This setup uses Docker to launch Prometheus and Grafana easily. + +- **QuickNode Account and API Key**: Make sure you have an [API key](https://dashboard.quicknode.com/api-keys) with appropriate permissions (`CONSOLE_REST`). + +## Getting Started + +1. Clone this repository: + +```sh +git clone https://github.com/quiknode-labs/qn-guide-examples.git +``` + +2. Navigate to the `grafana-dashboard` folder: + +```sh +cd qn-guide-examples/console-api/grafana-dashboard +``` + +3. Update the `prometheus.yaml` file in the `prometheus` folder with your QuickNode API key. + +4. Launch Prometheus and Grafana using Docker Compose: + +```sh +docker-compose up +``` + +5. Access Grafana by navigating to http://localhost:3000 in your web browser. + +For more detailed instructions, please refer to the guide: [How to Build a Grafana Dashboard to Monitor Your RPC Infrastructure](https://www.quicknode.com/guides/quicknode-products/console-api/how-to-build-a-grafana-dashboard-to-monitor-your-rpc-infrastructure). \ No newline at end of file diff --git a/console-api/grafana-dashboard/docker-compose.yaml b/console-api/grafana-dashboard/docker-compose.yaml new file mode 100644 index 0000000..a423b12 --- /dev/null +++ b/console-api/grafana-dashboard/docker-compose.yaml @@ -0,0 +1,23 @@ +services: + prometheus: + image: prom/prometheus:latest + volumes: + - ./prometheus/prometheus.yaml:/etc/prometheus/prometheus.yaml + command: + - '--config.file=/etc/prometheus/prometheus.yaml' + ports: + - "9090:9090" + + grafana: + image: grafana/grafana:latest + depends_on: + - prometheus + ports: + - "3000:3000" + volumes: + - ./grafana/provisioning/dashboards/main.yaml:/etc/grafana/provisioning/dashboards/main.yaml + - ./grafana/provisioning/datasources:/etc/grafana/provisioning/datasources + - ./grafana/dashboards:/var/lib/grafana/dashboards + environment: + - GF_SECURITY_ADMIN_PASSWORD=password + diff --git a/console-api/grafana-dashboard/grafana/dashboards/QuickNode Console API.json b/console-api/grafana-dashboard/grafana/dashboards/QuickNode Console API.json new file mode 100644 index 0000000..302e55c --- /dev/null +++ b/console-api/grafana-dashboard/grafana/dashboards/QuickNode Console API.json @@ -0,0 +1,584 @@ +{ + "__inputs": [ + { + "name": "DS_PROMETHEUS_ID", + "label": "Prometheus Data Source", + "description": "", + "type": "datasource", + "pluginId": "prometheus", + "pluginName": "Prometheus" + } + ], + "annotations": { + "list": [ + { + "builtIn": 1, + "datasource": { + "type": "grafana", + "uid": "-- Grafana --" + }, + "enable": true, + "hide": true, + "iconColor": "rgba(0, 211, 255, 1)", + "name": "Annotations & Alerts", + "type": "dashboard" + } + ] + }, + "editable": true, + "fiscalYearStartMonth": 0, + "graphTooltip": 0, + "id": 1, + "links": [], + "panels": [ + { + "datasource": { + "default": true, + "type": "prometheus" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "thresholds" + }, + "mappings": [], + "thresholds": { + "mode": "percentage", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 0, + "y": 0 + }, + "id": 2, + "options": { + "minVizHeight": 75, + "minVizWidth": 75, + "orientation": "auto", + "reduceOptions": { + "calcs": ["lastNotNull"], + "fields": "", + "values": false + }, + "showThresholdLabels": false, + "showThresholdMarkers": true, + "sizing": "auto" + }, + "pluginVersion": "11.2.0", + "targets": [ + { + "datasource": { + "type": "prometheus" + }, + "disableTextWrap": false, + "editorMode": "builder", + "expr": "sum(quicknode_rpc_requests)", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "QuickNode RPC Requests", + "type": "gauge" + }, + { + "datasource": { + "default": true, + "type": "prometheus" + }, + "fieldConfig": { + "defaults": { + "color": { + "fixedColor": "green", + "mode": "thresholds" + }, + "fieldMinMax": false, + "mappings": [], + "thresholds": { + "mode": "percentage", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 12, + "y": 0 + }, + "id": 1, + "options": { + "minVizHeight": 75, + "minVizWidth": 75, + "orientation": "auto", + "reduceOptions": { + "calcs": ["lastNotNull"], + "fields": "", + "values": false + }, + "showThresholdLabels": false, + "showThresholdMarkers": true, + "sizing": "auto" + }, + "pluginVersion": "11.2.0", + "targets": [ + { + "datasource": { + "type": "prometheus" + }, + "disableTextWrap": false, + "editorMode": "code", + "expr": "sum(quicknode_rpc_credits)", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "QuickNode RPC Credits", + "type": "gauge" + }, + { + "datasource": { + "default": true, + "type": "prometheus" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "palette-classic" + }, + "custom": { + "axisBorderShow": false, + "axisCenteredZero": false, + "axisColorMode": "text", + "axisLabel": "", + "axisPlacement": "auto", + "barAlignment": 0, + "barWidthFactor": 0.6, + "drawStyle": "line", + "fillOpacity": 0, + "gradientMode": "none", + "hideFrom": { + "legend": false, + "tooltip": false, + "viz": false + }, + "insertNulls": false, + "lineInterpolation": "linear", + "lineWidth": 1, + "pointSize": 5, + "scaleDistribution": { + "type": "linear" + }, + "showPoints": "auto", + "spanNulls": false, + "stacking": { + "group": "A", + "mode": "none" + }, + "thresholdsStyle": { + "mode": "off" + } + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 0, + "y": 8 + }, + "id": 3, + "options": { + "legend": { + "calcs": [], + "displayMode": "list", + "placement": "bottom", + "showLegend": true + }, + "tooltip": { + "mode": "single", + "sort": "none" + } + }, + "targets": [ + { + "datasource": { + "type": "prometheus" + }, + "disableTextWrap": false, + "editorMode": "code", + "expr": "sum_over_time(quicknode_rpc_requests[30d])", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "QuickNode RPC Requests Total Last 30 days", + "type": "timeseries" + }, + { + "datasource": { + "default": true, + "type": "prometheus" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "palette-classic" + }, + "custom": { + "axisBorderShow": false, + "axisCenteredZero": false, + "axisColorMode": "text", + "axisLabel": "", + "axisPlacement": "auto", + "barAlignment": 0, + "barWidthFactor": 0.6, + "drawStyle": "line", + "fillOpacity": 0, + "gradientMode": "none", + "hideFrom": { + "legend": false, + "tooltip": false, + "viz": false + }, + "insertNulls": false, + "lineInterpolation": "linear", + "lineWidth": 1, + "pointSize": 5, + "scaleDistribution": { + "type": "linear" + }, + "showPoints": "auto", + "spanNulls": false, + "stacking": { + "group": "A", + "mode": "none" + }, + "thresholdsStyle": { + "mode": "off" + } + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 12, + "y": 8 + }, + "id": 4, + "options": { + "legend": { + "calcs": [], + "displayMode": "list", + "placement": "bottom", + "showLegend": true + }, + "tooltip": { + "mode": "single", + "sort": "none" + } + }, + "targets": [ + { + "datasource": { + "type": "prometheus" + }, + "disableTextWrap": false, + "editorMode": "code", + "expr": "sum_over_time(quicknode_rpc_credits[30d])", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "QuickNode RPC Credits Total Last 30 days", + "type": "timeseries" + }, + { + "datasource": { + "default": true, + "type": "prometheus" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "palette-classic" + }, + "custom": { + "axisBorderShow": false, + "axisCenteredZero": false, + "axisColorMode": "text", + "axisLabel": "", + "axisPlacement": "auto", + "barAlignment": 0, + "barWidthFactor": 0.6, + "drawStyle": "line", + "fillOpacity": 0, + "gradientMode": "none", + "hideFrom": { + "legend": false, + "tooltip": false, + "viz": false + }, + "insertNulls": false, + "lineInterpolation": "linear", + "lineWidth": 1, + "pointSize": 5, + "scaleDistribution": { + "type": "linear" + }, + "showPoints": "auto", + "spanNulls": false, + "stacking": { + "group": "A", + "mode": "none" + }, + "thresholdsStyle": { + "mode": "off" + } + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 0, + "y": 16 + }, + "id": 5, + "options": { + "legend": { + "calcs": [], + "displayMode": "list", + "placement": "bottom", + "showLegend": true + }, + "tooltip": { + "mode": "single", + "sort": "none" + } + }, + "targets": [ + { + "datasource": { + "type": "prometheus" + }, + "disableTextWrap": false, + "editorMode": "builder", + "expr": "sum by(status, subdomain, label) (quicknode_rpc_response_status)", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "QuickNode Endpoint Response Status", + "type": "timeseries" + }, + { + "datasource": { + "default": true, + "type": "prometheus" + }, + "fieldConfig": { + "defaults": { + "color": { + "mode": "palette-classic" + }, + "custom": { + "axisBorderShow": false, + "axisCenteredZero": false, + "axisColorMode": "text", + "axisLabel": "", + "axisPlacement": "auto", + "barAlignment": 0, + "barWidthFactor": 0.6, + "drawStyle": "line", + "fillOpacity": 0, + "gradientMode": "none", + "hideFrom": { + "legend": false, + "tooltip": false, + "viz": false + }, + "insertNulls": false, + "lineInterpolation": "linear", + "lineWidth": 1, + "pointSize": 5, + "scaleDistribution": { + "type": "linear" + }, + "showPoints": "auto", + "spanNulls": false, + "stacking": { + "group": "A", + "mode": "none" + }, + "thresholdsStyle": { + "mode": "off" + } + }, + "mappings": [], + "thresholds": { + "mode": "absolute", + "steps": [ + { + "color": "green", + "value": null + }, + { + "color": "red", + "value": 80 + } + ] + } + }, + "overrides": [] + }, + "gridPos": { + "h": 8, + "w": 12, + "x": 12, + "y": 16 + }, + "id": 6, + "options": { + "legend": { + "calcs": [], + "displayMode": "list", + "placement": "bottom", + "showLegend": true + }, + "tooltip": { + "mode": "single", + "sort": "none" + } + }, + "targets": [ + { + "datasource": { + "type": "prometheus" + }, + "disableTextWrap": false, + "editorMode": "builder", + "expr": "max by(label, subdomain, method, method) (quicknode_rpc_response_time_max)", + "fullMetaSearch": false, + "includeNullMetadata": true, + "instant": false, + "legendFormat": "__auto", + "range": true, + "refId": "A", + "useBackend": false + } + ], + "title": "QuickNode Endpoint Response Time Max", + "type": "timeseries" + } + ], + "schemaVersion": 39, + "tags": [], + "templating": { + "list": [] + }, + "time": { + "from": "now-30m", + "to": "now" + }, + "timepicker": {}, + "timezone": "browser", + "title": "QuickNode Console API", + "uid": "edysjf1q674e8b", + "version": 1, + "weekStart": "" +} diff --git a/console-api/grafana-dashboard/grafana/provisioning/dashboards/main.yaml b/console-api/grafana-dashboard/grafana/provisioning/dashboards/main.yaml new file mode 100755 index 0000000..57d3797 --- /dev/null +++ b/console-api/grafana-dashboard/grafana/provisioning/dashboards/main.yaml @@ -0,0 +1,12 @@ +apiVersion: 1 + +providers: + - name: "Dashboard provider" + orgId: 1 + type: file + disableDeletion: false + updateIntervalSeconds: 10 + allowUiUpdates: false + options: + path: /var/lib/grafana/dashboards + foldersFromFilesStructure: true \ No newline at end of file diff --git a/console-api/grafana-dashboard/grafana/provisioning/datasources/prometheus-source.yaml b/console-api/grafana-dashboard/grafana/provisioning/datasources/prometheus-source.yaml new file mode 100644 index 0000000..f88db84 --- /dev/null +++ b/console-api/grafana-dashboard/grafana/provisioning/datasources/prometheus-source.yaml @@ -0,0 +1,9 @@ +apiVersion: 1 + +datasources: + - name: Prometheus + type: prometheus + access: proxy + url: http://prometheus:9090 + isDefault: true + editable: true \ No newline at end of file diff --git a/console-api/grafana-dashboard/prometheus/prometheus.yaml b/console-api/grafana-dashboard/prometheus/prometheus.yaml new file mode 100644 index 0000000..fba7d22 --- /dev/null +++ b/console-api/grafana-dashboard/prometheus/prometheus.yaml @@ -0,0 +1,12 @@ +global: + scrape_interval: 30s + +scrape_configs: + - job_name: "quicknode_prometheus_exporter" + metrics_path: "v0/prometheus/metrics" + scheme: "http" + authorization: + type: "bearer" + credentials: "" + static_configs: + - targets: ["api.quicknode.com"]