PostgreSQL Source Code git master
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
globals.c
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * globals.c
4 * global variable declarations
5 *
6 * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
7 * Portions Copyright (c) 1994, Regents of the University of California
8 *
9 *
10 * IDENTIFICATION
11 * src/backend/utils/init/globals.c
12 *
13 * NOTES
14 * Globals used all over the place should be declared here and not
15 * in other modules.
16 *
17 *-------------------------------------------------------------------------
18 */
19#include "postgres.h"
20
21#include "common/file_perm.h"
22#include "libpq/libpq-be.h"
23#include "libpq/pqcomm.h"
24#include "miscadmin.h"
26#include "storage/procnumber.h"
27#include "storage/procsignal.h"
28
29
31
32volatile sig_atomic_t InterruptPending = false;
33volatile sig_atomic_t QueryCancelPending = false;
34volatile sig_atomic_t ProcDiePending = false;
35volatile sig_atomic_t CheckClientConnectionPending = false;
36volatile sig_atomic_t ClientConnectionLost = false;
37volatile sig_atomic_t IdleInTransactionSessionTimeoutPending = false;
38volatile sig_atomic_t TransactionTimeoutPending = false;
39volatile sig_atomic_t IdleSessionTimeoutPending = false;
40volatile sig_atomic_t ProcSignalBarrierPending = false;
41volatile sig_atomic_t LogMemoryContextPending = false;
42volatile sig_atomic_t PublishMemoryContextPending = false;
43volatile sig_atomic_t IdleStatsUpdateTimeoutPending = false;
47
56
57/*
58 * MyLatch points to the latch that should be used for signal handling by the
59 * current process. It will either point to a process local latch if the
60 * current process does not have a PGPROC entry in that moment, or to
61 * PGPROC->procLatch if it has. Thus it can always be used in signal handlers,
62 * without checking for its existence.
63 */
64struct Latch *MyLatch;
65
66/*
67 * DataDir is the absolute path to the top level of the PGDATA directory tree.
68 * Except during early startup, this is also the server's working directory;
69 * most code therefore can simply use relative paths and not reference DataDir
70 * explicitly.
71 */
72char *DataDir = NULL;
73
74/*
75 * Mode of the data directory. The default is 0700 but it may be changed in
76 * checkDataDir() to 0750 if the data directory actually has that mode.
77 */
79
80char OutputFileName[MAXPGPATH]; /* debugging output file */
81
82char my_exec_path[MAXPGPATH]; /* full path to my executable */
83char pkglib_path[MAXPGPATH]; /* full path to lib directory */
84
85#ifdef EXEC_BACKEND
86char postgres_exec_path[MAXPGPATH]; /* full path to backend */
87
88/* note: currently this is not valid in backend processes */
89#endif
90
92
94
96
98
100
101/*
102 * DatabasePath is the path (relative to DataDir) of my database's
103 * primary directory, ie, its directory in the default tablespace.
104 */
105char *DatabasePath = NULL;
106
108
109/*
110 * IsPostmasterEnvironment is true in a postmaster process and any postmaster
111 * child process; it is false in a standalone process (bootstrap or
112 * standalone backend). IsUnderPostmaster is true in postmaster child
113 * processes. Note that "child process" includes all children, not only
114 * regular backends. These should be set correctly as early as possible
115 * in the execution of a process, so that error handling will do the right
116 * things if an error should occur during process initialization.
117 *
118 * These are initialized for the bootstrap/standalone case.
119 */
121bool IsUnderPostmaster = false;
122bool IsBinaryUpgrade = false;
123
124bool ExitOnAnyError = false;
125
129
130bool enableFsync = true;
132int work_mem = 4096;
136
137/*
138 * Primary determinants of sizes of shared-memory structures.
139 *
140 * MaxBackends is computed by PostmasterMain after modules have had a chance to
141 * register background workers.
142 */
143int NBuffers = 16384;
148
149/* GUC parameters for vacuum */
151
157
158int VacuumCostBalance = 0; /* working state for vacuum */
159bool VacuumCostActive = false;
160
161/* configurable SLRU buffer sizes */
uint8_t uint8
Definition: c.h:500
uint32_t uint32
Definition: c.h:502
int64 TimestampTz
Definition: timestamp.h:39
#define PG_DIR_MODE_OWNER
Definition: file_perm.h:32
int multixact_offset_buffers
Definition: globals.c:164
volatile sig_atomic_t IdleStatsUpdateTimeoutPending
Definition: globals.c:43
bool MyDatabaseHasLoginEventTriggers
Definition: globals.c:99
volatile sig_atomic_t LogMemoryContextPending
Definition: globals.c:41
volatile sig_atomic_t ProcSignalBarrierPending
Definition: globals.c:40
ProcNumber ParallelLeaderProcNumber
Definition: globals.c:93
double hash_mem_multiplier
Definition: globals.c:133
struct ClientSocket * MyClientSocket
Definition: globals.c:51
volatile sig_atomic_t InterruptPending
Definition: globals.c:32
volatile sig_atomic_t IdleSessionTimeoutPending
Definition: globals.c:39
bool IsBinaryUpgrade
Definition: globals.c:122
int VacuumCostLimit
Definition: globals.c:155
volatile uint32 QueryCancelHoldoffCount
Definition: globals.c:45
int DateStyle
Definition: globals.c:126
int max_parallel_maintenance_workers
Definition: globals.c:135
int NBuffers
Definition: globals.c:143
int MyPMChildSlot
Definition: globals.c:55
ProtocolVersion FrontendProtocol
Definition: globals.c:30
pid_t PostmasterPid
Definition: globals.c:107
volatile sig_atomic_t IdleInTransactionSessionTimeoutPending
Definition: globals.c:37
volatile uint32 InterruptHoldoffCount
Definition: globals.c:44
volatile sig_atomic_t TransactionTimeoutPending
Definition: globals.c:38
int transaction_buffers
Definition: globals.c:168
int MyProcPid
Definition: globals.c:48
bool enableFsync
Definition: globals.c:130
ProcNumber MyProcNumber
Definition: globals.c:91
int VacuumCostPageMiss
Definition: globals.c:153
char pkglib_path[MAXPGPATH]
Definition: globals.c:83
bool VacuumCostActive
Definition: globals.c:159
bool IsUnderPostmaster
Definition: globals.c:121
int MaxConnections
Definition: globals.c:144
int multixact_member_buffers
Definition: globals.c:163
int data_directory_mode
Definition: globals.c:78
int VacuumCostBalance
Definition: globals.c:158
volatile sig_atomic_t ClientConnectionLost
Definition: globals.c:36
bool allowSystemTableMods
Definition: globals.c:131
int maintenance_work_mem
Definition: globals.c:134
Oid MyDatabaseTableSpace
Definition: globals.c:97
char MyCancelKey[MAX_CANCEL_KEY_LENGTH]
Definition: globals.c:53
volatile uint32 CritSectionCount
Definition: globals.c:46
int max_parallel_workers
Definition: globals.c:146
int MaxBackends
Definition: globals.c:147
char * DataDir
Definition: globals.c:72
volatile sig_atomic_t QueryCancelPending
Definition: globals.c:33
int VacuumCostPageDirty
Definition: globals.c:154
TimestampTz MyStartTimestamp
Definition: globals.c:50
bool ExitOnAnyError
Definition: globals.c:124
uint8 MyCancelKeyLength
Definition: globals.c:54
int IntervalStyle
Definition: globals.c:128
int notify_buffers
Definition: globals.c:165
bool IsPostmasterEnvironment
Definition: globals.c:120
struct Port * MyProcPort
Definition: globals.c:52
int work_mem
Definition: globals.c:132
int VacuumBufferUsageLimit
Definition: globals.c:150
pg_time_t MyStartTime
Definition: globals.c:49
volatile sig_atomic_t PublishMemoryContextPending
Definition: globals.c:42
int VacuumCostPageHit
Definition: globals.c:152
struct Latch * MyLatch
Definition: globals.c:64
char OutputFileName[MAXPGPATH]
Definition: globals.c:80
int commit_timestamp_buffers
Definition: globals.c:162
double VacuumCostDelay
Definition: globals.c:156
int subtransaction_buffers
Definition: globals.c:167
volatile sig_atomic_t ProcDiePending
Definition: globals.c:34
char * DatabasePath
Definition: globals.c:105
int DateOrder
Definition: globals.c:127
volatile sig_atomic_t CheckClientConnectionPending
Definition: globals.c:35
int max_worker_processes
Definition: globals.c:145
char my_exec_path[MAXPGPATH]
Definition: globals.c:82
Oid MyDatabaseId
Definition: globals.c:95
int serializable_buffers
Definition: globals.c:166
#define USE_ISO_DATES
Definition: miscadmin.h:237
#define DATEORDER_MDY
Definition: miscadmin.h:245
#define INTSTYLE_POSTGRES
Definition: miscadmin.h:257
#define MAXPGPATH
int64 pg_time_t
Definition: pgtime.h:23
#define InvalidOid
Definition: postgres_ext.h:35
unsigned int Oid
Definition: postgres_ext.h:30
uint32 ProtocolVersion
Definition: pqcomm.h:99
#define INVALID_PROC_NUMBER
Definition: procnumber.h:26
int ProcNumber
Definition: procnumber.h:24
#define MAX_CANCEL_KEY_LENGTH
Definition: procsignal.h:68
Definition: latch.h:114
Definition: libpq-be.h:129