pangolin_exporter

Форк
0
/
pg_replication.go 
88 строк · 2.2 Кб
1
// Copyright 2023 The Prometheus Authors
2
// Licensed under the Apache License, Version 2.0 (the "License");
3
// you may not use this file except in compliance with the License.
4
// You may obtain a copy of the License at
5
//
6
// http://www.apache.org/licenses/LICENSE-2.0
7
//
8
// Unless required by applicable law or agreed to in writing, software
9
// distributed under the License is distributed on an "AS IS" BASIS,
10
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
// See the License for the specific language governing permissions and
12
// limitations under the License.
13

14
package collector
15

16
import (
17
	"context"
18

19
	"github.com/prometheus/client_golang/prometheus"
20
)
21

22
const replicationSubsystem = "replication"
23

24
func init() {
25
	registerCollector(replicationSubsystem, defaultEnabled, NewPGReplicationCollector)
26
}
27

28
type PGReplicationCollector struct {
29
}
30

31
func NewPGReplicationCollector(collectorConfig) (Collector, error) {
32
	return &PGReplicationCollector{}, nil
33
}
34

35
var (
36
	pgReplicationLag = prometheus.NewDesc(
37
		prometheus.BuildFQName(
38
			namespace,
39
			replicationSubsystem,
40
			"lag_seconds",
41
		),
42
		"Replication lag behind master in seconds",
43
		[]string{}, nil,
44
	)
45
	pgReplicationIsReplica = prometheus.NewDesc(
46
		prometheus.BuildFQName(
47
			namespace,
48
			replicationSubsystem,
49
			"is_replica",
50
		),
51
		"Indicates if the server is a replica",
52
		[]string{}, nil,
53
	)
54

55
	pgReplicationQuery = `SELECT
56
	CASE
57
		WHEN NOT pg_is_in_recovery() THEN 0
58
                WHEN pg_last_wal_receive_lsn () = pg_last_wal_replay_lsn () THEN 0
59
		ELSE GREATEST (0, EXTRACT(EPOCH FROM (now() - pg_last_xact_replay_timestamp())))
60
	END AS lag,
61
	CASE
62
		WHEN pg_is_in_recovery() THEN 1
63
		ELSE 0
64
	END as is_replica`
65
)
66

67
func (c *PGReplicationCollector) Update(ctx context.Context, instance *instance, ch chan<- prometheus.Metric) error {
68
	db := instance.getDB()
69
	row := db.QueryRowContext(ctx,
70
		pgReplicationQuery,
71
	)
72

73
	var lag float64
74
	var isReplica int64
75
	err := row.Scan(&lag, &isReplica)
76
	if err != nil {
77
		return err
78
	}
79
	ch <- prometheus.MustNewConstMetric(
80
		pgReplicationLag,
81
		prometheus.GaugeValue, lag,
82
	)
83
	ch <- prometheus.MustNewConstMetric(
84
		pgReplicationIsReplica,
85
		prometheus.GaugeValue, float64(isReplica),
86
	)
87
	return nil
88
}
89

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.