1. 28 Apr, 2021 1 commit
  2. 27 Apr, 2021 5 commits
    • Andrew Dunstan's avatar
      Improve logic in PostgresVersion.pm · fa26eba2
      Andrew Dunstan authored
      Handle the situation where perl swaps the order of operands of
      the comparison operator. See `perldoc overload` for details:
      
      The third argument is set to TRUE if (and only if) the two
      operands have been swapped. Perl may do this to ensure that the
      first argument ($self) is an object implementing the overloaded
      operation, in line with general object calling conventions.
      fa26eba2
    • Fujii Masao's avatar
      doc: Review for "Allow TRUNCATE command to truncate foreign tables". · 0c8f4086
      Fujii Masao authored
      Typos, corrections and language improvements in the docs.
      
      Author: Justin Pryzby, Fujii Masao
      Reviewed-by: Bharath Rupireddy, Justin Pryzby, Fujii Masao
      Discussion: https://postgr.es/m/20210411041658.GB14564@telsasoft.com
      0c8f4086
    • Fujii Masao's avatar
      Don't pass "ONLY" options specified in TRUNCATE to foreign data wrapper. · 8e9ea08b
      Fujii Masao authored
      Commit 8ff1c946 allowed TRUNCATE command to truncate foreign tables.
      Previously the information about "ONLY" options specified in TRUNCATE
      command were passed to the foreign data wrapper. Then postgres_fdw
      constructed the TRUNCATE command to issue the remote server and
      included "ONLY" options in it based on the passed information.
      
      On the other hand, "ONLY" options specified in SELECT, UPDATE or DELETE
      have no effect when accessing or modifying the remote table, i.e.,
      are not passed to the foreign data wrapper. So it's inconsistent to
      make only TRUNCATE command pass the "ONLY" options to the foreign data
      wrapper. Therefore this commit changes the TRUNCATE command so that
      it doesn't pass the "ONLY" options to the foreign data wrapper,
      for the consistency with other statements. Also this commit changes
      postgres_fdw so that it always doesn't include "ONLY" options in
      the TRUNCATE command that it constructs.
      
      Author: Fujii Masao
      Reviewed-by: Bharath Rupireddy, Kyotaro Horiguchi, Justin Pryzby, Zhihong Yu
      Discussion: https://postgr.es/m/551ed8c1-f531-818b-664a-2cecdab99cd8@oss.nttdata.com
      8e9ea08b
    • Amit Kapila's avatar
      Use HTAB for replication slot statistics. · 3fa17d37
      Amit Kapila authored
      Previously, we used to use the array of size max_replication_slots to
      store stats for replication slots. But that had two problems in the cases
      where a message for dropping a slot gets lost: 1) the stats for the new
      slot are not recorded if the array is full and 2) writing beyond the end
      of the array if the user reduces the max_replication_slots.
      
      This commit uses HTAB for replication slot statistics, resolving both
      problems. Now, pgstat_vacuum_stat() search for all the dead replication
      slots in stats hashtable and tell the collector to remove them. To avoid
      showing the stats for the already-dropped slots, pg_stat_replication_slots
      view searches slot stats by the slot name taken from pg_replication_slots.
      
      Also, we send a message for creating a slot at slot creation, initializing
      the stats. This reduces the possibility that the stats are accumulated
      into the old slot stats when a message for dropping a slot gets lost.
      
      Reported-by: Andres Freund
      Author: Sawada Masahiko, test case by Vignesh C
      Reviewed-by: Amit Kapila, Vignesh C, Dilip Kumar
      Discussion: https://postgr.es/m/20210319185247.ldebgpdaxsowiflw@alap3.anarazel.de
      3fa17d37
    • Amit Kapila's avatar
      Fix Logical Replication of Truncate in synchronous commit mode. · e7eea52b
      Amit Kapila authored
      The Truncate operation acquires an exclusive lock on the target relation
      and indexes. It then waits for logical replication of the operation to
      finish at commit. Now because we are acquiring the shared lock on the
      target index to get index attributes in pgoutput while sending the
      changes for the Truncate operation, it leads to a deadlock.
      
      Actually, we don't need to acquire a lock on the target index as we build
      the cache entry using a historic snapshot and all the later changes are
      absorbed while decoding WAL. So, we wrote a special purpose function for
      logical replication to get a bitmap of replica identity attribute numbers
      where we get that information without locking the target index.
      
      We decided not to backpatch this as there doesn't seem to be any field
      complaint about this issue since it was introduced in commit 5dfd1e5a in
      v11.
      
      Reported-by: Haiying Tang
      Author: Takamichi Osumi, test case by Li Japin
      Reviewed-by: Amit Kapila, Ajin Cherian
      Discussion: https://postgr.es/m/OS0PR01MB6113C2499C7DC70EE55ADB82FB759@OS0PR01MB6113.jpnprd01.prod.outlook.com
      e7eea52b
  3. 26 Apr, 2021 8 commits
  4. 25 Apr, 2021 2 commits
  5. 24 Apr, 2021 5 commits
  6. 23 Apr, 2021 13 commits
  7. 22 Apr, 2021 6 commits
    • Tom Lane's avatar
      Don't crash on reference to an un-available system column. · d479d002
      Tom Lane authored
      Adopt a more consistent policy about what slot-type-specific
      getsysattr functions should do when system attributes are not
      available.  To wit, they should all throw the same user-oriented
      error, rather than variously crashing or emitting developer-oriented
      messages.
      
      This closes a identifiable problem in commits a71cfc56b and
      3fb93103a (in v13 and v12), so back-patch into those branches,
      along with a test case to try to ensure we don't break it again.
      It is not known that any of the former crash cases are reachable
      in HEAD, but this seems like a good safety improvement in any case.
      
      Discussion: https://postgr.es/m/141051591267657@mail.yandex.ru
      d479d002
    • Peter Eisentraut's avatar
      197d33cc
    • Alvaro Herrera's avatar
      Fix uninitialized memory bug · 43b55ec4
      Alvaro Herrera authored
      Have interested callers of find_inheritance_children set the
      detached_exist value to false prior to calling it, so that that routine
      only has to set it true in the rare cases where it is necessary.  Don't
      touch it otherwise.
      
      Per buildfarm member thorntail (which reported a UBSan failure here).
      43b55ec4
    • Bruce Momjian's avatar
      doc: mention <link> can be inside of <command>, but not <xref> · 84f15ccd
      Bruce Momjian authored
      This was discussed in commit 9081bddb.
      
      Reported-by: Peter Eisentraut
      
      Discussion: https://postgr.es/m/flat/87o8pco34z.fsf@wibble.ilmari.org
      84f15ccd
    • Andrew Dunstan's avatar
      Make PostgresVersion code a bit more robust and simple. · 502dc6df
      Andrew Dunstan authored
      per gripe from Alvaro Herrera.
      502dc6df
    • Alvaro Herrera's avatar
      Fix relcache inconsistency hazard in partition detach · 8aba9322
      Alvaro Herrera authored
      During queries coming from ri_triggers.c, we need to omit partitions
      that are marked pending detach -- otherwise, the RI query is tricked
      into allowing a row into the referencing table whose corresponding row
      is in the detached partition.  Which is bogus: once the detach operation
      completes, the row becomes an orphan.
      
      However, the code was not doing that in repeatable-read transactions,
      because relcache kept a copy of the partition descriptor that included
      the partition, and used it in the RI query.  This commit changes the
      partdesc cache code to only keep descriptors that aren't dependent on
      a snapshot (namely: those where no detached partition exist, and those
      where detached partitions are included).  When a partdesc-without-
      detached-partitions is requested, we create one afresh each time; also,
      those partdescs are stored in PortalContext instead of
      CacheMemoryContext.
      
      find_inheritance_children gets a new output *detached_exist boolean,
      which indicates whether any partition marked pending-detach is found.
      Its "include_detached" input flag is changed to "omit_detached", because
      that name captures desired the semantics more naturally.
      CreatePartitionDirectory() and RelationGetPartitionDesc() arguments are
      identically renamed.
      
      This was noticed because a buildfarm member that runs with relcache
      clobbering, which would not keep the improperly cached partdesc, broke
      one test, which led us to realize that the expected output of that test
      was bogus.  This commit also corrects that expected output.
      
      Author: Amit Langote <amitlangote09@gmail.com>
      Author: Álvaro Herrera <alvherre@alvh.no-ip.org>
      Discussion: https://postgr.es/m/3269784.1617215412@sss.pgh.pa.us
      8aba9322