From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org> |
Cc: | ITAGAKI Takahiro <itagaki(dot)takahiro(at)oss(dot)ntt(dot)co(dot)jp>, Bruce Momjian <bruce(at)momjian(dot)us>, pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: CSStorm occurred again by postgreSQL8.2 |
Date: | 2006-09-14 01:45:35 |
Message-ID: | 22080.1158198335@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers pgsql-patches |
I wrote:
> ... it seems like in the
> case where RecordSubTransactionCommit detects that the subxact has not
> stored its XID anywhere, we could immediately remove the XID from
> the PGPROC array, just as if it had aborted. This would avoid chewing
> subxid slots for cases such as exception blocks in plpgsql that are
> not modifying the database, but just catching computational errors.
(and later realized that Alvaro had had the same idea awhile back, but
I don't have his message at hand).
I looked into this a bit more; it seems like basically it should only
take addition of
else
XidCacheRemoveRunningXids(xid, 0, NULL);
to the bottom of RecordSubTransactionCommit(), plus suitable adjustment
of the comments in both routines. However, there's a problem: if we
delete a second-level subxact's XID from PGPROC, and later its upper
subtransaction aborts, XidCacheRemoveRunningXids will emit scary
warnings when it doesn't find the sub-subxact in PGPROC. This could
doubtless be fixed with sufficient jiggery-pokery --- simply removing
the debug warnings would be a brute-force answer, but I'd like to find
something a bit less brute-force. Maybe drop the sub-subxact from its
parent's list immediately, instead of carrying it forward?
Anyway, given that there's this one nonobvious gotcha, there might be
others. My recommendation is that we take this off the open-items list
for 8.2 and revisit it in the 8.3 cycle when there's more time.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2006-09-14 01:55:01 | Not-so-open items |
Previous Message | Mark Dilger | 2006-09-14 01:23:11 | Re: Fixed length data types issue |
From | Date | Subject | |
---|---|---|---|
Next Message | Gregory Stark | 2006-09-14 11:05:52 | Re: CSStorm occurred again by postgreSQL8.2 |
Previous Message | Tom Lane | 2006-09-13 23:44:04 | Re: Some editing of docs for create index concurrently |