gooderp18绿色标准版
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

64 lines
2.1KB

  1. /*-------------------------------------------------------------------------
  2. *
  3. * twophase.h
  4. * Two-phase-commit related declarations.
  5. *
  6. *
  7. * Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group
  8. * Portions Copyright (c) 1994, Regents of the University of California
  9. *
  10. * src/include/access/twophase.h
  11. *
  12. *-------------------------------------------------------------------------
  13. */
  14. #ifndef TWOPHASE_H
  15. #define TWOPHASE_H
  16. #include "access/xlogdefs.h"
  17. #include "access/xact.h"
  18. #include "datatype/timestamp.h"
  19. #include "storage/lock.h"
  20. /*
  21. * GlobalTransactionData is defined in twophase.c; other places have no
  22. * business knowing the internal definition.
  23. */
  24. typedef struct GlobalTransactionData *GlobalTransaction;
  25. /* GUC variable */
  26. extern PGDLLIMPORT int max_prepared_xacts;
  27. extern Size TwoPhaseShmemSize(void);
  28. extern void TwoPhaseShmemInit(void);
  29. extern void AtAbort_Twophase(void);
  30. extern void PostPrepare_Twophase(void);
  31. extern PGPROC *TwoPhaseGetDummyProc(TransactionId xid, bool lock_held);
  32. extern BackendId TwoPhaseGetDummyBackendId(TransactionId xid, bool lock_held);
  33. extern GlobalTransaction MarkAsPreparing(TransactionId xid, const char *gid,
  34. TimestampTz prepared_at,
  35. Oid owner, Oid databaseid);
  36. extern void StartPrepare(GlobalTransaction gxact);
  37. extern void EndPrepare(GlobalTransaction gxact);
  38. extern bool StandbyTransactionIdIsPrepared(TransactionId xid);
  39. extern TransactionId PrescanPreparedTransactions(TransactionId **xids_p,
  40. int *nxids_p);
  41. extern void ParsePrepareRecord(uint8 info, char *xlrec,
  42. xl_xact_parsed_prepare *parsed);
  43. extern void StandbyRecoverPreparedTransactions(void);
  44. extern void RecoverPreparedTransactions(void);
  45. extern void CheckPointTwoPhase(XLogRecPtr redo_horizon);
  46. extern void FinishPreparedTransaction(const char *gid, bool isCommit);
  47. extern void PrepareRedoAdd(char *buf, XLogRecPtr start_lsn,
  48. XLogRecPtr end_lsn, RepOriginId origin_id);
  49. extern void PrepareRedoRemove(TransactionId xid, bool giveWarning);
  50. extern void restoreTwoPhaseData(void);
  51. #endif /* TWOPHASE_H */
上海开阖软件有限公司 沪ICP备12045867号-1