/src/postgres/src/backend/utils/activity/pgstat_archiver.c
Line | Count | Source |
1 | | /* ------------------------------------------------------------------------- |
2 | | * |
3 | | * pgstat_archiver.c |
4 | | * Implementation of archiver statistics. |
5 | | * |
6 | | * This file contains the implementation of archiver statistics. It is kept |
7 | | * separate from pgstat.c to enforce the line between the statistics access / |
8 | | * storage implementation and the details about individual types of |
9 | | * statistics. |
10 | | * |
11 | | * Copyright (c) 2001-2025, PostgreSQL Global Development Group |
12 | | * |
13 | | * IDENTIFICATION |
14 | | * src/backend/utils/activity/pgstat_archiver.c |
15 | | * ------------------------------------------------------------------------- |
16 | | */ |
17 | | |
18 | | #include "postgres.h" |
19 | | |
20 | | #include "utils/pgstat_internal.h" |
21 | | #include "utils/timestamp.h" |
22 | | |
23 | | |
24 | | /* |
25 | | * Report archiver statistics |
26 | | */ |
27 | | void |
28 | | pgstat_report_archiver(const char *xlog, bool failed) |
29 | 0 | { |
30 | 0 | PgStatShared_Archiver *stats_shmem = &pgStatLocal.shmem->archiver; |
31 | 0 | TimestampTz now = GetCurrentTimestamp(); |
32 | |
|
33 | 0 | pgstat_begin_changecount_write(&stats_shmem->changecount); |
34 | |
|
35 | 0 | if (failed) |
36 | 0 | { |
37 | 0 | ++stats_shmem->stats.failed_count; |
38 | 0 | memcpy(&stats_shmem->stats.last_failed_wal, xlog, |
39 | 0 | sizeof(stats_shmem->stats.last_failed_wal)); |
40 | 0 | stats_shmem->stats.last_failed_timestamp = now; |
41 | 0 | } |
42 | 0 | else |
43 | 0 | { |
44 | 0 | ++stats_shmem->stats.archived_count; |
45 | 0 | memcpy(&stats_shmem->stats.last_archived_wal, xlog, |
46 | 0 | sizeof(stats_shmem->stats.last_archived_wal)); |
47 | 0 | stats_shmem->stats.last_archived_timestamp = now; |
48 | 0 | } |
49 | |
|
50 | 0 | pgstat_end_changecount_write(&stats_shmem->changecount); |
51 | 0 | } |
52 | | |
53 | | /* |
54 | | * Support function for the SQL-callable pgstat* functions. Returns |
55 | | * a pointer to the archiver statistics struct. |
56 | | */ |
57 | | PgStat_ArchiverStats * |
58 | | pgstat_fetch_stat_archiver(void) |
59 | 0 | { |
60 | 0 | pgstat_snapshot_fixed(PGSTAT_KIND_ARCHIVER); |
61 | |
|
62 | 0 | return &pgStatLocal.snapshot.archiver; |
63 | 0 | } |
64 | | |
65 | | void |
66 | | pgstat_archiver_init_shmem_cb(void *stats) |
67 | 0 | { |
68 | 0 | PgStatShared_Archiver *stats_shmem = (PgStatShared_Archiver *) stats; |
69 | |
|
70 | 0 | LWLockInitialize(&stats_shmem->lock, LWTRANCHE_PGSTATS_DATA); |
71 | 0 | } |
72 | | |
73 | | void |
74 | | pgstat_archiver_reset_all_cb(TimestampTz ts) |
75 | 0 | { |
76 | 0 | PgStatShared_Archiver *stats_shmem = &pgStatLocal.shmem->archiver; |
77 | | |
78 | | /* see explanation above PgStatShared_Archiver for the reset protocol */ |
79 | 0 | LWLockAcquire(&stats_shmem->lock, LW_EXCLUSIVE); |
80 | 0 | pgstat_copy_changecounted_stats(&stats_shmem->reset_offset, |
81 | 0 | &stats_shmem->stats, |
82 | 0 | sizeof(stats_shmem->stats), |
83 | 0 | &stats_shmem->changecount); |
84 | 0 | stats_shmem->stats.stat_reset_timestamp = ts; |
85 | 0 | LWLockRelease(&stats_shmem->lock); |
86 | 0 | } |
87 | | |
88 | | void |
89 | | pgstat_archiver_snapshot_cb(void) |
90 | 0 | { |
91 | 0 | PgStatShared_Archiver *stats_shmem = &pgStatLocal.shmem->archiver; |
92 | 0 | PgStat_ArchiverStats *stat_snap = &pgStatLocal.snapshot.archiver; |
93 | 0 | PgStat_ArchiverStats *reset_offset = &stats_shmem->reset_offset; |
94 | 0 | PgStat_ArchiverStats reset; |
95 | |
|
96 | 0 | pgstat_copy_changecounted_stats(stat_snap, |
97 | 0 | &stats_shmem->stats, |
98 | 0 | sizeof(stats_shmem->stats), |
99 | 0 | &stats_shmem->changecount); |
100 | |
|
101 | 0 | LWLockAcquire(&stats_shmem->lock, LW_SHARED); |
102 | 0 | memcpy(&reset, reset_offset, sizeof(stats_shmem->stats)); |
103 | 0 | LWLockRelease(&stats_shmem->lock); |
104 | | |
105 | | /* compensate by reset offsets */ |
106 | 0 | if (stat_snap->archived_count == reset.archived_count) |
107 | 0 | { |
108 | 0 | stat_snap->last_archived_wal[0] = 0; |
109 | 0 | stat_snap->last_archived_timestamp = 0; |
110 | 0 | } |
111 | 0 | stat_snap->archived_count -= reset.archived_count; |
112 | |
|
113 | 0 | if (stat_snap->failed_count == reset.failed_count) |
114 | 0 | { |
115 | 0 | stat_snap->last_failed_wal[0] = 0; |
116 | 0 | stat_snap->last_failed_timestamp = 0; |
117 | 0 | } |
118 | 0 | stat_snap->failed_count -= reset.failed_count; |
119 | 0 | } |