mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Reconsider page size for large objects: rather than stuffing disk pages
as full as possible, seems better to use a tuple size around BLCKSZ/4 so that less space is wasted when a LO tuple is updated. Also, this lets us use a logical page size that's an exact power of two, avoiding partial-page writes when client is sending us stuff in power-of-2 buffer chunks.
This commit is contained in:
		| @@ -37,7 +37,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2000, PostgreSQL, Inc |  * Portions Copyright (c) 1996-2000, PostgreSQL, Inc | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $Id: catversion.h,v 1.52 2000/10/24 01:38:41 tgl Exp $ |  * $Id: catversion.h,v 1.53 2000/10/24 03:34:15 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -53,6 +53,6 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /*							yyyymmddN */ | /*							yyyymmddN */ | ||||||
| #define CATALOG_VERSION_NO	200010232 | #define CATALOG_VERSION_NO	200010233 | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2000, PostgreSQL, Inc |  * Portions Copyright (c) 1996-2000, PostgreSQL, Inc | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  * Portions Copyright (c) 1994, Regents of the University of California | ||||||
|  * |  * | ||||||
|  * $Id: large_object.h,v 1.18 2000/10/24 01:38:43 tgl Exp $ |  * $Id: large_object.h,v 1.19 2000/10/24 03:34:53 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -47,13 +47,18 @@ typedef struct LargeObjectDesc { | |||||||
| /* | /* | ||||||
|  * Each "page" (tuple) of a large object can hold this much data |  * Each "page" (tuple) of a large object can hold this much data | ||||||
|  * |  * | ||||||
|  * Calculation is max tuple size less tuple header, loid field (Oid), |  * We could set this as high as BLCKSZ less some overhead, but it seems | ||||||
|  * pageno field (int32), and varlena header of data (int32).  Note we |  * better to make it a smaller value, so that not as much space is used | ||||||
|  * assume none of the fields will be NULL, hence no need for null bitmap. |  * up when a page-tuple is updated.  Note that the value is deliberately | ||||||
|  |  * chosen large enough to trigger the tuple toaster, so that we will | ||||||
|  |  * attempt to compress page tuples in-line.  (But they won't be moved off | ||||||
|  |  * unless the user creates a toast-table for pg_largeobject...) | ||||||
|  |  * | ||||||
|  |  * Also, it seems to be a smart move to make the page size be a power of 2, | ||||||
|  |  * since clients will often be written to send data in power-of-2 blocks. | ||||||
|  |  * This avoids unnecessary tuple updates caused by partial-page writes. | ||||||
|  */ |  */ | ||||||
| #define	LOBLKSIZE		(MaxTupleSize \ | #define	LOBLKSIZE		(BLCKSZ / 4) | ||||||
| 						 - MAXALIGN(offsetof(HeapTupleHeaderData, t_bits)) \ |  | ||||||
| 						 - sizeof(Oid) - sizeof(int32) * 2) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user