PostgreSQL Source Code  git master
pgstat_checkpointer.c
Go to the documentation of this file.
1 /* -------------------------------------------------------------------------
2  *
3  * pgstat_checkpointer.c
4  * Implementation of checkpoint statistics.
5  *
6  * This file contains the implementation of checkpoint 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-2024, PostgreSQL Global Development Group
12  *
13  * IDENTIFICATION
14  * src/backend/utils/activity/pgstat_checkpointer.c
15  * -------------------------------------------------------------------------
16  */
17 
18 #include "postgres.h"
19 
20 #include "utils/pgstat_internal.h"
21 
22 
24 
25 
26 /*
27  * Report checkpointer and IO statistics
28  */
29 void
31 {
32  /* We assume this initializes to zeroes */
33  static const PgStat_CheckpointerStats all_zeroes;
35 
38 
39  /*
40  * This function can be called even if nothing at all has happened. In
41  * this case, avoid unnecessarily modifying the stats entry.
42  */
43  if (memcmp(&PendingCheckpointerStats, &all_zeroes,
44  sizeof(all_zeroes)) == 0)
45  return;
46 
48 
49 #define CHECKPOINTER_ACC(fld) stats_shmem->stats.fld += PendingCheckpointerStats.fld
50  CHECKPOINTER_ACC(num_timed);
51  CHECKPOINTER_ACC(num_requested);
52  CHECKPOINTER_ACC(restartpoints_timed);
53  CHECKPOINTER_ACC(restartpoints_requested);
54  CHECKPOINTER_ACC(restartpoints_performed);
55  CHECKPOINTER_ACC(write_time);
56  CHECKPOINTER_ACC(sync_time);
57  CHECKPOINTER_ACC(buffers_written);
58 #undef CHECKPOINTER_ACC
59 
61 
62  /*
63  * Clear out the statistics buffer, so it can be re-used.
64  */
66 
67  /*
68  * Report IO statistics
69  */
70  pgstat_flush_io(false);
71 }
72 
73 /*
74  * pgstat_fetch_stat_checkpointer() -
75  *
76  * Support function for the SQL-callable pgstat* functions. Returns
77  * a pointer to the checkpointer statistics struct.
78  */
81 {
83 
85 }
86 
87 void
89 {
91 
93 }
94 
95 void
97 {
99 
100  /* see explanation above PgStatShared_Checkpointer for the reset protocol */
101  LWLockAcquire(&stats_shmem->lock, LW_EXCLUSIVE);
103  &stats_shmem->stats,
104  sizeof(stats_shmem->stats),
105  &stats_shmem->changecount);
106  stats_shmem->stats.stat_reset_timestamp = ts;
107  LWLockRelease(&stats_shmem->lock);
108 }
109 
110 void
112 {
114  PgStat_CheckpointerStats *reset_offset = &stats_shmem->reset_offset;
116 
118  &stats_shmem->stats,
119  sizeof(stats_shmem->stats),
120  &stats_shmem->changecount);
121 
122  LWLockAcquire(&stats_shmem->lock, LW_SHARED);
123  memcpy(&reset, reset_offset, sizeof(stats_shmem->stats));
124  LWLockRelease(&stats_shmem->lock);
125 
126  /* compensate by reset offsets */
127 #define CHECKPOINTER_COMP(fld) pgStatLocal.snapshot.checkpointer.fld -= reset.fld;
128  CHECKPOINTER_COMP(num_timed);
129  CHECKPOINTER_COMP(num_requested);
130  CHECKPOINTER_COMP(restartpoints_timed);
131  CHECKPOINTER_COMP(restartpoints_requested);
132  CHECKPOINTER_COMP(restartpoints_performed);
133  CHECKPOINTER_COMP(write_time);
134  CHECKPOINTER_COMP(sync_time);
135  CHECKPOINTER_COMP(buffers_written);
136 #undef CHECKPOINTER_COMP
137 }
#define Assert(condition)
Definition: c.h:858
#define MemSet(start, val, len)
Definition: c.h:1020
int64 TimestampTz
Definition: timestamp.h:39
bool LWLockAcquire(LWLock *lock, LWLockMode mode)
Definition: lwlock.c:1168
void LWLockRelease(LWLock *lock)
Definition: lwlock.c:1781
void LWLockInitialize(LWLock *lock, int tranche_id)
Definition: lwlock.c:707
@ LWTRANCHE_PGSTATS_DATA
Definition: lwlock.h:205
@ LW_SHARED
Definition: lwlock.h:115
@ LW_EXCLUSIVE
Definition: lwlock.h:114
void pgstat_snapshot_fixed(PgStat_Kind kind)
Definition: pgstat.c:981
PgStat_LocalState pgStatLocal
Definition: pgstat.c:201
@ PGSTAT_KIND_CHECKPOINTER
Definition: pgstat.h:50
void pgstat_checkpointer_snapshot_cb(void)
void pgstat_checkpointer_init_shmem_cb(void *stats)
#define CHECKPOINTER_COMP(fld)
void pgstat_report_checkpointer(void)
void pgstat_checkpointer_reset_all_cb(TimestampTz ts)
PgStat_CheckpointerStats PendingCheckpointerStats
PgStat_CheckpointerStats * pgstat_fetch_stat_checkpointer(void)
#define CHECKPOINTER_ACC(fld)
static void pgstat_end_changecount_write(uint32 *cc)
#define pgstat_assert_is_up()
static void pgstat_begin_changecount_write(uint32 *cc)
static void pgstat_copy_changecounted_stats(void *dst, void *src, size_t len, uint32 *cc)
bool pgstat_flush_io(bool nowait)
Definition: pgstat_io.c:173
void reset(void)
Definition: sql-declare.c:600
PgStat_CheckpointerStats reset_offset
PgStat_CheckpointerStats stats
TimestampTz stat_reset_timestamp
Definition: pgstat.h:271
PgStat_Snapshot snapshot
PgStat_ShmemControl * shmem
PgStatShared_Checkpointer checkpointer
PgStat_CheckpointerStats checkpointer