1. 06 Nov, 2021 3 commits
    • Tom Lane's avatar
      Second-draft release notes for 14.1. · 01a11c77
      Tom Lane authored
      Add latest commits.  Fix some typos and infelicitous wording
      (thanks to Justin Pryzby for proof-reading).
      01a11c77
    • Tomas Vondra's avatar
      Fix handling of NaN values in BRIN minmax multi · f7829feb
      Tomas Vondra authored
      When calculating distance between float4/float8 values, we need to be a
      bit more careful about NaN values in order not to trigger assert. We
      consider NaN values to be equal (distace 0.0) and in infinite distance
      from all other values.
      
      On builds without asserts, this issue is mostly harmless - the ranges
      may be merged in less efficient order, but the index is still correct.
      
      Per report from Andreas Seltenreich. Backpatch to 14, where this new
      BRIN opclass was introduced.
      
      Reported-by: Andreas Seltenreich
      Discussion: https://postgr.es/m/87r1bw9ukm.fsf@credativ.de
      f7829feb
    • Tom Lane's avatar
      First-draft release notes for 14.1. · 39387228
      Tom Lane authored
      As usual, the release notes for other branches will be made by cutting
      these down, but put them up for community review first.
      
      Also as usual for a .1 release, there are some entries here that
      are not really relevant for v14 because they already appeared in 14.0.
      Those'll be removed later.
      39387228
  2. 05 Nov, 2021 2 commits
  3. 03 Nov, 2021 3 commits
  4. 02 Nov, 2021 3 commits
    • Peter Geoghegan's avatar
      Don't overlook indexes during parallel VACUUM. · 61a86ed5
      Peter Geoghegan authored
      Commit b4af70cb, which simplified state managed by VACUUM, performed
      refactoring of parallel VACUUM in passing.  Confusion about the exact
      details of the tasks that the leader process is responsible for led to
      code that made it possible for parallel VACUUM to miss a subset of the
      table's indexes entirely.  Specifically, indexes that fell under the
      min_parallel_index_scan_size size cutoff were missed.  These indexes are
      supposed to be vacuumed by the leader (alongside any parallel unsafe
      indexes), but weren't vacuumed at all.  Affected indexes could easily
      end up with duplicate heap TIDs, once heap TIDs were recycled for new
      heap tuples.  This had generic symptoms that might be seen with almost
      any index corruption involving structural inconsistencies between an
      index and its table.
      
      To fix, make sure that the parallel VACUUM leader process performs any
      required index vacuuming for indexes that happen to be below the size
      cutoff.  Also document the design of parallel VACUUM with these
      below-size-cutoff indexes.
      
      It's unclear how many users might be affected by this bug.  There had to
      be at least three indexes on the table to hit the bug: a smaller index,
      plus at least two additional indexes that themselves exceed the size
      cutoff.  Cases with just one additional index would not run into
      trouble, since the parallel VACUUM cost model requires two
      larger-than-cutoff indexes on the table to apply any parallel
      processing.  Note also that autovacuum was not affected, since it never
      uses parallel processing.
      
      Test case based on tests from a larger patch to test parallel VACUUM by
      Masahiko Sawada.
      
      Many thanks to Kamigishi Rei for her invaluable help with tracking this
      problem down.
      
      Author: Peter Geoghegan <pg@bowt.ie>
      Author: Masahiko Sawada <sawada.mshk@gmail.com>
      Reported-By: default avatarKamigishi Rei <iijima.yun@koumakan.jp>
      Reported-By: default avatarAndrew Gierth <andrew@tao11.riddles.org.uk>
      Diagnosed-By: default avatarAndres Freund <andres@anarazel.de>
      Bug: #17245
      Discussion: https://postgr.es/m/17245-ddf06aaf85735f36@postgresql.org
      Discussion: https://postgr.es/m/20211030023740.qbnsl2xaoh2grq3d@alap3.anarazel.de
      Backpatch: 14-, where the refactoring commit appears.
      61a86ed5
    • Tom Lane's avatar
      Fix variable lifespan in ExecInitCoerceToDomain(). · 16a56774
      Tom Lane authored
      This undoes a mistake in 1ec7679f: domainval and domainnull were
      meant to live across loop iterations, but they were incorrectly
      moved inside the loop.  The effect was only to emit useless extra
      EEOP_MAKE_READONLY steps, so it's not a big deal; nonetheless,
      back-patch to v13 where the mistake was introduced.
      
      Ranier Vilela
      
      Discussion: https://postgr.es/m/CAEudQAqXuhbkaAp-sGH6dR6Nsq7v28_0TPexHOm6FiDYqwQD-w@mail.gmail.com
      16a56774
    • Tom Lane's avatar
      Avoid O(N^2) behavior in SyncPostCheckpoint(). · 08cfa598
      Tom Lane authored
      As in commits 6301c3ada and e9d9ba2a4, avoid doing repetitive
      list_delete_first() operations, since that would be expensive when
      there are many files waiting to be unlinked.  This is a slightly
      larger change than in those cases.  We have to keep the list state
      valid for calls to AbsorbSyncRequests(), so it's necessary to invent a
      "canceled" field instead of immediately deleting PendingUnlinkEntry
      entries.  Also, because we might not be able to process all the
      entries, we need a new list primitive list_delete_first_n().
      
      list_delete_first_n() is almost list_copy_tail(), but it modifies the
      input List instead of making a new copy.  I found a couple of existing
      uses of the latter that could profitably use the new function.  (There
      might be more, but the other callers look like they probably shouldn't
      overwrite the input List.)
      
      As before, back-patch to v13.
      
      Discussion: https://postgr.es/m/CD2F0E7F-9822-45EC-A411-AE56F14DEA9F@amazon.com
      08cfa598
  5. 01 Nov, 2021 3 commits
  6. 31 Oct, 2021 2 commits
    • Tom Lane's avatar
      Don't try to read a multi-GB pg_stat_statements file in one call. · 7104e0b2
      Tom Lane authored
      Windows fails on a request to read() more than INT_MAX bytes,
      and perhaps other platforms could have similar issues.  Let's
      adjust this code to read at most 1GB per call.
      
      (One would not have thought the file could get that big, but now
      we have a field report of trouble, so it can.  We likely ought to
      add some mechanism to limit the size of the query-texts file
      separately from the size of the hash table.  That is not this
      patch, though.)
      
      Per bug #17254 from Yusuke Egashira.  It's been like this for
      awhile, so back-patch to all supported branches.
      
      Discussion: https://postgr.es/m/17254-a926c89dc03375c2@postgresql.org
      7104e0b2
    • Tom Lane's avatar
      Avoid O(N^2) behavior when the standby process releases many locks. · 8424dfce
      Tom Lane authored
      When replaying a transaction that held many exclusive locks on the
      primary, a standby server's startup process would expend O(N^2)
      effort on manipulating the list of locks.  This code was fine when
      written, but commit 1cff1b95 made repetitive list_delete_first()
      calls inefficient, as explained in its commit message.  Fix by just
      iterating the list normally, and releasing storage only when done.
      (This'd be inadequate if we needed to recover from an error occurring
      partway through; but we don't.)
      
      Back-patch to v13 where 1cff1b95 came in.
      
      Nathan Bossart
      
      Discussion: https://postgr.es/m/CD2F0E7F-9822-45EC-A411-AE56F14DEA9F@amazon.com
      8424dfce
  7. 29 Oct, 2021 2 commits
    • Peter Geoghegan's avatar
      Demote pg_unreachable() in heapam to an assertion. · bd9f4cf0
      Peter Geoghegan authored
      Commit d168b666, which overhauled index deletion, added a
      pg_unreachable() to the end of a sort comparator used when sorting heap
      TIDs from an index page.  This allows the compiler to apply
      optimizations that assume that the heap TIDs from the index AM must
      always be unique.
      
      That doesn't seem like a good idea now, given recent reports of
      corruption involving duplicate TIDs in indexes on Postgres 14.  Demote
      to an assertion, just in case.
      
      Backpatch: 14-, where index deletion was overhauled.
      bd9f4cf0
    • Tom Lane's avatar
      Update time zone data files to tzdata release 2021e. · 0c8a40b3
      Tom Lane authored
      DST law changes in Fiji, Jordan, Palestine, and Samoa.  Historical
      corrections for Barbados, Cook Islands, Guyana, Niue, Portugal, and
      Tonga.
      
      Also, the Pacific/Enderbury zone has been renamed to Pacific/Kanton.
      The following zones have been merged into nearby, more-populous zones
      whose clocks have agreed since 1970: Africa/Accra, America/Atikokan,
      America/Blanc-Sablon, America/Creston, America/Curacao,
      America/Nassau, America/Port_of_Spain, Antarctica/DumontDUrville,
      and Antarctica/Syowa.
      0c8a40b3
  8. 28 Oct, 2021 2 commits
    • Tom Lane's avatar
      Improve contrib/amcheck's tests for CREATE INDEX CONCURRENTLY. · b1f943d2
      Tom Lane authored
      Commits fdd965d07 and 3cd9c3b92 tested CREATE INDEX CONCURRENTLY by
      launching two separate pgbench runs concurrently.  This was needed so
      that only a single client thread would run CREATE INDEX CONCURRENTLY,
      avoiding deadlock between two CICs.  However, there's a better way,
      which is to use an advisory lock to prevent concurrent CICs.  That's
      better in part because the test code is shorter and more readable, but
      mostly because it automatically scales things to launch an appropriate
      number of CICs relative to the number of INSERT transactions.
      As committed, typically half to three-quarters of the CIC transactions
      were pointless because the INSERT transactions had already stopped.
      
      In passing, remove background_pgbench, which was added to support
      these tests and isn't needed anymore.  We can always put it back
      if we find a use for it later.
      
      Back-patch to v12; older pgbench versions lack the
      conditional-execution features needed for this method.
      
      Tom Lane and Andrey Borodin
      
      Discussion: https://postgr.es/m/139687.1635277318@sss.pgh.pa.us
      b1f943d2
    • Michael Paquier's avatar
      doc: Fix link to SELinux user guide in sepgsql page · da7d0fb1
      Michael Paquier authored
      Reported-by: Anton Voloshin
      Discussion: https://postgr.es/m/15a86d4e-a237-1acd-18a2-fd69730f1ab9@postgrespro.ru
      Backpatch-through: 10
      da7d0fb1
  9. 27 Oct, 2021 3 commits
  10. 26 Oct, 2021 3 commits
  11. 24 Oct, 2021 2 commits
    • Noah Misch's avatar
      Fix CREATE INDEX CONCURRENTLY for the newest prepared transactions. · a5b9a000
      Noah Misch authored
      The purpose of commit 8a54e12a was to
      fix this, and it sufficed when the PREPARE TRANSACTION completed before
      the CIC looked for lock conflicts.  Otherwise, things still broke.  As
      before, in a cluster having used CIC while having enabled prepared
      transactions, queries that use the resulting index can silently fail to
      find rows.  It may be necessary to reindex to recover from past
      occurrences; REINDEX CONCURRENTLY suffices.  Fix this for future index
      builds by making CIC wait for arbitrarily-recent prepared transactions
      and for ordinary transactions that may yet PREPARE TRANSACTION.  As part
      of that, have PREPARE TRANSACTION transfer locks to its dummy PGPROC
      before it calls ProcArrayClearTransaction().  Back-patch to 9.6 (all
      supported versions).
      
      Andrey Borodin, reviewed (in earlier versions) by Andres Freund.
      
      Discussion: https://postgr.es/m/01824242-AA92-4FE9-9BA7-AEBAFFEA3D0C@yandex-team.ru
      a5b9a000
    • Noah Misch's avatar
      Avoid race in RelationBuildDesc() affecting CREATE INDEX CONCURRENTLY. · dde966ef
      Noah Misch authored
      CIC and REINDEX CONCURRENTLY assume backends see their catalog changes
      no later than each backend's next transaction start.  That failed to
      hold when a backend absorbed a relevant invalidation in the middle of
      running RelationBuildDesc() on the CIC index.  Queries that use the
      resulting index can silently fail to find rows.  Fix this for future
      index builds by making RelationBuildDesc() loop until it finishes
      without accepting a relevant invalidation.  It may be necessary to
      reindex to recover from past occurrences; REINDEX CONCURRENTLY suffices.
      Back-patch to 9.6 (all supported versions).
      
      Noah Misch and Andrey Borodin, reviewed (in earlier versions) by Andres
      Freund.
      
      Discussion: https://postgr.es/m/20210730022548.GA1940096@gust.leadboat.com
      dde966ef
  12. 23 Oct, 2021 1 commit
  13. 22 Oct, 2021 3 commits
  14. 21 Oct, 2021 3 commits
  15. 20 Oct, 2021 2 commits
  16. 19 Oct, 2021 3 commits