ADR 0004 - PostgreSQL Metrics Exporter
Author |
Łukasz Widera |
---|---|
Owner |
Schedar |
Reviewers |
Schedar |
Date Created |
2023-02-21 |
Date Updated |
2023-03-07 |
Status |
implemented |
Tags |
postgresql,service,monitoring,metrics |
Summary
We’re using a custom exporter to export metrics about PostgreSQL. |
Problem
We need to monitor availability of PostgreSQL by VSHN to be able to measure "Up" SLI
Goals
-
Measure the "UP" SLI
-
Idea how to integrate SLI Exceptions
Solutions
PostgreSQL Server Exporter by Stackgres
Stackgres provides us built-in PostgreSQL Server Exporter that runs as a side car, which exposes multiple useful metrics.
One especially useful from availability monitoring perspective is pg_up
. The pg_up
is a metric is set to 1
if all preconfigured SQL query checks are properly executed and no one returned an error. We could use this metric more or less directly as our "Up" SLI.
One limitation if this metric is that it could generate false positives in situation when one of the queries will be dropped by PostgreSQL. The exporter also connects locally, which makes such solution unreliable for us, because our customers connects in different way, connection has to pass through pg bouncer, it has to reuse user credentials and shouldn’t generate false positives if one of two pods crash. It doesn’t check for WRITE operations, only read operations.
PostgreSQL Server Exporter by VSHN
We can also deploy our own PostgreSQL Server Exporter instance in the database namespace.
We’ll scrape the same metrics, we’ll also be able to measure uptime using pg_up metric, but in this solution we can configure exporter to use the same route, user, password and database as our customers use. It doesn’t check for WRITE operations, only read operations.
Custom Prometheus Exporter
We can write our own exporter that checks connectivity using the same connection details as the service user. It can also execute WRITE queries and it’ll return for example pg_up metric if connectivity and file system are both OK.
The exporter can be then reused for other services to do the same job for us. The custom exporter allows us to be more flexible in what we measure and how we handle the exceptions to the availability guarantee, as we can handle them in a general purpose programming language instead of having to model them in PromQL.
Requirements/Options | Exporter provided by VSHN | Exporter provided by Stackgres | Custom exporter |
---|---|---|---|
Checks network connectivity |
✅ |
✅ |
✅ |
Login to database the same way as the service user |
✅ |
❌ |
✅ |
Easily integrates with Prometheus |
✅ |
✅ |
✅ |
Read queries check |
✅ |
✅ |
✅ |
Write queries check |
❌ |
❌ |
✅ |
Rationale
The best solution would be to write a custom exporter, because it’ll do exactly what we want with minimal footprint on resources.
It disadvantage is:
-
Cost - We need time to write and maintain code
Its advantages are:
-
Flexibility - We can extend and adapt code and functionalities as we want to.
-
Reliability - The exporter reuses service user credentials and connection method so we’re sure the service user can connect to the database without issues.
-
Optimization - Minimal footprint and resource usage.
-
Resolution - We can write its logic to perform checks each second, this way we can better measure how long PostgreSQL is up or down.
-
Write Checks - Compared to the PostgreSQL Server Exporter we can actually check if PostgreSQL is operational by performing write operations on the database.