Setting up Grafana
Included Dashboards
pgMonitor comes with several dashboards ready to be used with automatic provisioning. They provide examples of using the metrics from the postgres_exporter and node_exporter. Since provisioned dashboards cannot be edited directly in the web interface, if any custom changes are desired, it is recommended to make a copy of them and make your changes there.
Filename | Dashboard Name | Description |
---|---|---|
etcd/ETCD_Details.json | ETCD Details | Provides details on the status of the ETCD cluster monitored by pgMonitor. |
linux/Filesystem_Details.json | Filesystem Details | Provides details on the filesystem metrics (disk usage, IO, etc). |
linux/Network_Details.json | Network Details | Provides details on network usage (utilization, traffic in/out, netstat, etc). |
linux/OS_Details.json | OS Details | Provides details on operating system metrics (cpu, memory, swap, disk usage). Links to Filesystem Details dashboard. |
linux/OS_Overview.json | OS Overview | Provides an overview that shows the up status of each system monitored by pgMonitor. |
postgres/Bloat_Details.json | Bloat Details | Provides details on database bloat (wasted space). Provides overview and top-n statistics. |
postgres/CRUD_Details.json | CRUD Details | Provides details on Create, Read, Update, Delete (CRUD) statistics on a per-table basis. |
postgres/PGBackrest.json | pgBackRest | Provides details on backups performed with pgBackRest. Also provides recovery window to show timeframe available for PITR. |
postgres/PG_Details.json | PostgreSQL Details | Provides detailed information for each PostgreSQL instance (connections, replication, wraparound, etc). |
postgres/postgres_exporter/PG_Overview_postgres_exporter.json | PostgreSQL Overview | Provides an overview of all PostgreSQL systems being monitored when the postgres_exporter is being used. Indicates whether a system is a Primary or Replica. Can click on each panel to open up the PostgreSQL Details for that system. |
postgres/sql_exporter/PG_Overview_sql_exporter.json | PostgreSQL Overview (sql_exporter) | Provides an overview of all PostgreSQL systems being monitored when the sql_exporter is being used. Indicates whether a system is a Primary or Replica. Can click on each panel to open up the PostgreSQL Details for that system. |
postgres/QueryStatistics.json | Query Statistics | Provides an overview of statistics collected by the pg_stat_statements extension. |
postgres/TableSize_Details.json | TableSize Details | Provides size details on a per-table basis for the given database. |
pgbouncer/direct/PGBouncer.json | PgBouncer (direct) | Provides details from the PgBouncer statistics views when connecting directly to PgBouncer with the sql_exporter. |
pgbouncer/fdw/PGBouncer.json | PgBouncer | Provides details from the PgBouncer statistics views when using the pgbouncer_fdw. |
prometheus/Prometheus_Alerts.json | Prometheus Alertsi | Provides a summary list of current and recent alerts that have fired in Prometheus. |
Installation
Package Install
There are RPM packages available to Crunchy Data customers through the Crunchy Customer Portal. To access the pgMonitor packages, please follow the same instructions for setting up access to the Crunchy Postgres packages.
If you install the below available packages, you can continue reading at the Setup section. Dashboards have been split up into different packages to allow users to only have dashboards that are relevant to their environment appear in the provisioned dashboards location.
Available Packages
Package Name | Description |
---|---|
grafana | Base package for grafana |
pgmonitor-grafana-extras-common | Crunchy files common for all Grafana installations (Ex. datasource & dashboard provisioning) |
pgmonitor-grafana-extras-etcd | Crunchy dashboards for etcd (etcd built-in exporter) |
pgmonitor-grafana-extras-linux | Crunchy dashboards for Linux OS metrics (node_exporter) |
pgmonitor-grafana-extras-haproxy | Crunchy dashboards for HAProxy (built-in exporter) |
pgmonitor-grafana-extras-pg | Crunchy dashboards for PostgreSQL metrics common to all PG exporters |
pgmonitor-grafana-extras-pg-postgres-exporter | Crunchy dashboards for metrics provided by postgres_exporter (see version 5 upgrade for deprecation notice) |
pgmonitor-grafana-extras-pg-sql-exporter | Crunchy dashboards for metrics provided by the sql_exporter |
pgmonitor-grafana-extras-pgbouncer-direct | Crunchy dashboards for PgBouncer metrics collected directly from bouncer via the sql_exporter |
pgmonitor-grafana-extras-pgbouncer-fdw | Crunchy dashboards for PgBouncer metrics collected via the pgbouncer_fdw |
pgmonitor-grafana-extras-prometheus | Crunchy dashboards for proividing direct Prometheus visualization (alerting) |
Non-Package Install
Create the following directories on your grafana server if they don’t exist:
mkdir -p /etc/grafana/provisioning/{datasources,dashboards}
mkdir -p /etc/grafana/crunchy_dashboards
pgmonitor Configuration File | System Location |
---|---|
grafana/crunchy_grafana_datasource.yml | /etc/grafana/provisioning/datasources/datasource.yml |
grafana/crunchy_grafana_dashboards.yml | /etc/grafana/provisioning/dashboards/dashboards.yml |
Review the crunchy_grafana_datasource.yml } file to ensure it is looking at your Prometheus database. The included file assumes Grafana, Prometheus, and Alertmanager are running on the same system. DO NOT CHANGE the datasource uid or name fields if you will be using the dashboards provided in this repo. They assume those values and will not work otherwise. Any other options can be changed as needed. Save the crunchy_grafana_datasource.yml file and rename it to /etc/grafana/provisioning/datasources/datasources.yml . Restart grafana and confirm through the web interface that the datasource was provisioned and working.
Review the crunchy_grafana_dashboards.yml file to ensure it’s looking at where you stored the provided dashboards. By default it is looking in /etc/grafana/crunchy_dashboards . Save this file and rename it to /etc/grafana/provisioning/dashboards/dashboards.yml . Restart grafana so it picks up the new config.
Save all of the desired .json dashboard files (see table above) to the /etc/grafana/crunchy_dashboards folder. All of them are not required, so if there is a dashboard you do not need, it can be left out.
Please note that due to the change from postgres_exporter to sql_exporter, and its ability to connect directly to pgBouncer to collect its metrics, some dashboards are specific to one exporter or the other. Please use the relevant dashboards accordingly based on their descriptions above.
Upgrading
- If you are upgrading to version 5.0 and transitioning to using the new sql_exporter, please see the documentation in Upgrading to pgMonitor v5.0.0
- See the CHANGELOG for full details on both major & minor version upgrades.
- Note that if you are using the included dashboards that are managed via the provisioning system, they will automatically be updated. If you’ve made any changes to configuration files and kept their default names, the package will not overwrite them and will instead make a new file with an *.rpmnew extension. You can compare your file and the new one and incorporate any changes as needed or desired.
Setup
Setup on RHEL
Configuration Database
By default Grafana uses an SQLite database to store configuration and dashboard information. We recommend using a PostgreSQL database for better long term scalability. Before doing any further configuration, including changing the default admin password, set the grafana.ini
to point to a postgresql instance that has a database created for it.
In psql run the following:
CREATE ROLE grafana WITH LOGIN;
CREATE DATABASE grafana;
ALTER DATABASE grafana OWNER TO grafana;
\password grafana
You may also need to adjust your pg_hba.conf
to allow grafana to connect to your database.
In your grafana.ini
, set the following options at a minimum with relevant values:
[database]
type = postgres
host = 127.0.0.1:5432
name = grafana
user = grafana
password = """mypassword"""
Now enable and start the grafana service
sudo systemctl enable grafana-server
sudo systemctl start grafana-server
sudo systemctl status grafana-server
Navigate to the web interface: https://<ip-address>:3000. Log in with admin/admin (be sure to change the admin password) and check settings to ensure the postgres options have been set and are working.
Datasource & Dashboard Provisioning
Grafana provides the ability to automatically provision datasources and dashboards via configuration files instead of having to manually import them either through the web interface or the API. Note that provisioned dashboards cannot be directly edited and saved via the web interface. See the Grafana documentation for how to edit/save provisioned dashboards: http://docs.grafana.org/administration/provisioning/#making-changes-to-a-provisioned-dashboard. If you’d like to customize these dashboards, we recommend first adding them via provisioning then saving them with a new name. You can then either manage them via the web interface or add them to the provisioning system.
The extras package takes care of putting all these files in place. If you did not use the Crunchy package to install Grafana, see the additional instructions above. Once that is done, the only additional setup that needs to be done is to set the “provisioning” option in the grafana.ini
to point to the top level directory if it hasn’t been done already.
[paths]
provisioning = /etc/grafana/provisioning