Re: Further XLogInsert scaling tweaking

From: Bruce Momjian <bruce(at)momjian(dot)us>
To: Heikki Linnakangas <hlinnakangas(at)vmware(dot)com>
Cc: PostgreSQL-development <pgsql-hackers(at)postgreSQL(dot)org>
Subject: Re: Further XLogInsert scaling tweaking
Date: 2013-09-03 03:32:40
Message-ID: 20130903033240.GE21874@momjian.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Mon, Sep 2, 2013 at 10:14:03AM +0300, Heikki Linnakangas wrote:
> diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c
> index 39c58d0..28e62ea 100644
> --- a/src/backend/access/transam/xlog.c
> +++ b/src/backend/access/transam/xlog.c
> @@ -428,8 +428,14 @@ typedef struct XLogCtlInsert
> uint64 CurrBytePos;
> uint64 PrevBytePos;
>
> - /* insertion slots, see above for details */
> - XLogInsertSlotPadded *insertSlots;
> + /*
> + * Make sure the above heavily-contended spinlock and byte positions are
> + * on their own cache line. In particular, the RedoRecPtr and full page
> + * write variables below should be on a different cache line. They are
> + * read on every WAL insertion, but updated rarely, and we don't want
> + * those reads to steal the cache line containing Curr/PrevBytePos.
> + */
> + char pad[128];

Do we adjust for cache line lengths anywhere else? PGPROC? Should it
be a global define?

--
Bruce Momjian <bruce(at)momjian(dot)us> http://momjian.us
EnterpriseDB http://enterprisedb.com

+ It's impossible for everything to be true. +

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Karl O. Pinc 2013-09-03 03:56:54 Re: backup.sgml-cmd-v003.patch
Previous Message Noah Misch 2013-09-03 03:31:50 Re: dynamic shared memory