Re: pgsql: postgres_fdw: Inherit the local transaction's access/deferrable - Mailing list pgsql-hackers

From Fujii Masao
Subject Re: pgsql: postgres_fdw: Inherit the local transaction's access/deferrable
Date
Msg-id ed2296f1-1a6b-4932-b870-5bb18c2591ae@oss.nttdata.com
Whole thread Raw
List pgsql-hackers

On 2025/06/01 17:34, Etsuro Fujita wrote:
> postgres_fdw: Inherit the local transaction's access/deferrable modes.
> 
> Previously, postgres_fdw always 1) opened a remote transaction in READ
> WRITE mode even when the local transaction was READ ONLY, causing a READ
> ONLY transaction using it that references a foreign table mapped to a
> remote view executing a volatile function to write in the remote side,
> and 2) opened the remote transaction in NOT DEFERRABLE mode even when
> the local transaction was DEFERRABLE, causing a SERIALIZABLE READ ONLY
> DEFERRABLE transaction using it to abort due to a serialization failure
> in the remote side.
> 
> To avoid these, modify postgres_fdw to open a remote transaction in the
> same access/deferrable modes as the local transaction.  This commit also
> modifies it to open a remote subtransaction in the same access mode as
> the local subtransaction.
> 
> Although these issues exist since the introduction of postgres_fdw,
> there have been no reports from the field.  So it seems fine to just fix
> them in master only.

I'm not sure this change should be considered a bug fix,
since the current behavior of postgres_fdw with a local read-only
transaction isn't clearly documented. Some users might see this
as a behavioral change rather than a fix. Anyway if we go with it,
shouldn't we document the change in the v18 release notes?

Regards,

-- 
Fujii Masao
NTT DATA Japan Corporation




pgsql-hackers by date:

Previous
From: Tom Lane
Date:
Subject: Re: Confused coding in PLy_traceback()
Next
From: jian he
Date:
Subject: Re: ALTER TABLE ALTER CONSTRAINT misleading error message