2016-01-21 03:51:34 +01:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* standbydef.h
|
|
|
|
* Frontend exposed definitions for hot standby mode.
|
|
|
|
*
|
|
|
|
*
|
2016-02-15 22:19:35 +01:00
|
|
|
* Portions Copyright (c) 1996-2016, PostgreSQL Global Development Group
|
2016-01-21 03:51:34 +01:00
|
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
|
|
*
|
|
|
|
* src/include/storage/standbydefs.h
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
#ifndef STANDBYDEFS_H
|
|
|
|
#define STANDBYDEFS_H
|
|
|
|
|
|
|
|
#include "access/xlogreader.h"
|
|
|
|
#include "lib/stringinfo.h"
|
|
|
|
#include "storage/lockdefs.h"
|
|
|
|
|
|
|
|
/* Recovery handlers for the Standby Rmgr (RM_STANDBY_ID) */
|
|
|
|
extern void standby_redo(XLogReaderState *record);
|
|
|
|
extern void standby_desc(StringInfo buf, XLogReaderState *record);
|
|
|
|
extern const char *standby_identify(uint8 info);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* XLOG message types
|
|
|
|
*/
|
|
|
|
#define XLOG_STANDBY_LOCK 0x00
|
|
|
|
#define XLOG_RUNNING_XACTS 0x10
|
|
|
|
|
|
|
|
typedef struct xl_standby_locks
|
|
|
|
{
|
|
|
|
int nlocks; /* number of entries in locks array */
|
|
|
|
xl_standby_lock locks[FLEXIBLE_ARRAY_MEMBER];
|
|
|
|
} xl_standby_locks;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* When we write running xact data to WAL, we use this structure.
|
|
|
|
*/
|
|
|
|
typedef struct xl_running_xacts
|
|
|
|
{
|
|
|
|
int xcnt; /* # of xact ids in xids[] */
|
|
|
|
int subxcnt; /* # of subxact ids in xids[] */
|
|
|
|
bool subxid_overflow; /* snapshot overflowed, subxids missing */
|
|
|
|
TransactionId nextXid; /* copy of ShmemVariableCache->nextXid */
|
|
|
|
TransactionId oldestRunningXid; /* *not* oldestXmin */
|
|
|
|
TransactionId latestCompletedXid; /* so we can set xmax */
|
|
|
|
|
|
|
|
TransactionId xids[FLEXIBLE_ARRAY_MEMBER];
|
|
|
|
} xl_running_xacts;
|
|
|
|
|
|
|
|
#endif /* STANDBYDEFS_H */
|