greenplumn pg_magic_oid 源码

  • 2022-08-18
  • 浏览 (439)

greenplumn pg_magic_oid 代码

文件路径:/src/include/catalog/pg_magic_oid.h

/*-------------------------------------------------------------------------
 *
 * pg_magic_oid.h
 *	  Magic oids
 *
 * Portions Copyright (c) 2009, Greenplum Inc.
 * Portions Copyright (c) 2012-Present VMware, Inc. or its affiliates.
 *
 *
 * IDENTIFICATION
 *	    src/include/catalog/pg_magic_oid.h
 *
 *-------------------------------------------------------------------------
 */

#ifndef PG_MAGIC_OID_H
#define PG_MAGIC_OID_H

/* ----------
 *		Object ID (OID) zero is InvalidOid.
 *
 *		OIDs 1-9999 are reserved for manual assignment (see .dat files in
 *		src/include/catalog/).  Of these, 8000-9999 are reserved for
 *		development purposes (such as in-progress patches and forks);
 *		they should not appear in released versions.
 *
 *		OIDs 10000-11999 are reserved for assignment by genbki.pl, for use
 *		when the .dat files in src/include/catalog/ do not specify an OID
 *		for a catalog entry that requires one.
 *
 *		OIDS 12000-16383 are reserved for assignment during initdb
 *		using the OID generator.  (We start the generator at 12000.)
 *
 *		OIDs beginning at 16384 are assigned from the OID generator
 *		during normal multiuser operation.  (We force the generator up to
 *		16384 as soon as we are in normal operation.)
 *
 * The choices of 8000, 10000 and 12000 are completely arbitrary, and can be
 * moved if we run low on OIDs in any category.  Changing the macros below,
 * and updating relevant documentation (see bki.sgml and RELEASE_CHANGES),
 * should be sufficient to do this.  Moving the 16384 boundary between
 * initdb-assigned OIDs and user-defined objects would be substantially
 * more painful, however, since some user-defined OIDs will appear in
 * on-disk data; such a change would probably break pg_upgrade.
 *
 * GPDB: we have some more built-in entries, so bumped FirstBoostrapObjectId
 * from 1200 to 12500.
 *
 * NOTE: if the OID generator wraps around, we skip over OIDs 0-16383
 * and resume with 16384.  This minimizes the odds of OID conflict, by not
 * reassigning OIDs that might have been assigned during initdb.
 * ----------
 */
#define FirstGenbkiObjectId		10000
#define FirstBootstrapObjectId	12500
#define FirstNormalObjectId		16384

/*
 * For the time being, we split the OID range so that newly added objects
 * won't conflict between GPDB and GPSQL.  If two merge into one in some day,
 * this boundary will disappear.
 */
#define LowestGPSQLBootstrapObjectId 7500

/*
 * Reserve a block of OIDs for use during binary upgrade. We create functions
 * needed during the upgrade here, but they are dropped after the ugprade, so
 * should not be present in other contexts. They need a reserved block of OIDs
 * to avoid colliding with user objects that are created later in the upgrade
 * process.
 */
#define FirstBinaryUpgradeReservedObjectId 9000
#define LastBinaryUpgradeReservedObjectId 9100

#endif

相关信息

greenplumn 源码目录

相关文章

greenplumn aoblkdir 源码

greenplumn aocatalog 源码

greenplumn aoseg 源码

greenplumn aovisimap 源码

greenplumn binary_upgrade 源码

greenplumn catalog 源码

greenplumn catversion 源码

greenplumn dependency 源码

greenplumn genbki 源码

greenplumn gp_configuration_history 源码

0  赞