Coverage Report

Created: 2025-10-09 06:07

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/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
}