1. 13 Apr, 2018 2 commits
  2. 12 Apr, 2018 11 commits
  3. 11 Apr, 2018 11 commits
    • Tom Lane's avatar
      Ignore nextOid when replaying an ONLINE checkpoint. · d1e90792
      Tom Lane authored
      The nextOid value is from the start of the checkpoint and may well be stale
      compared to values from more recent XLOG_NEXTOID records.  Previously, we
      adopted it anyway, allowing the OID counter to go backwards during a crash.
      While this should be harmless, it contributed to the severity of the bug
      fixed in commit 0408e1ed, by allowing duplicate TOAST OIDs to be assigned
      immediately following a crash.  Without this error, that issue would only
      have arisen when TOAST objects just younger than a multiple of 2^32 OIDs
      were deleted and then not vacuumed in time to avoid a conflict.
      
      Pavan Deolasee
      
      Discussion: https://postgr.es/m/CABOikdOgWT2hHkYG3Wwo2cyZJq2zfs1FH0FgX-=h4OLosXHf9w@mail.gmail.com
      d1e90792
    • Tom Lane's avatar
      Do not select new object OIDs that match recently-dead entries. · 0408e1ed
      Tom Lane authored
      When selecting a new OID, we take care to avoid picking one that's already
      in use in the target table, so as not to create duplicates after the OID
      counter has wrapped around.  However, up to now we used SnapshotDirty when
      scanning for pre-existing entries.  That ignores committed-dead rows, so
      that we could select an OID matching a deleted-but-not-yet-vacuumed row.
      While that mostly worked, it has two problems:
      
      * If recently deleted, the dead row might still be visible to MVCC
      snapshots, creating a risk for duplicate OIDs when examining the catalogs
      within our own transaction.  Such duplication couldn't be visible outside
      the object-creating transaction, though, and we've heard few if any field
      reports corresponding to such a symptom.
      
      * When selecting a TOAST OID, deleted toast rows definitely *are* visible
      to SnapshotToast, and will remain so until vacuumed away.  This leads to
      a conflict that will manifest in errors like "unexpected chunk number 0
      (expected 1) for toast value nnnnn".  We've been seeing reports of such
      errors from the field for years, but the cause was unclear before.
      
      The fix is simple: just use SnapshotAny to search for conflicting rows.
      This results in a slightly longer window before object OIDs can be
      recycled, but that seems unlikely to create any large problems.
      
      Pavan Deolasee
      
      Discussion: https://postgr.es/m/CABOikdOgWT2hHkYG3Wwo2cyZJq2zfs1FH0FgX-=h4OLosXHf9w@mail.gmail.com
      0408e1ed
    • Heikki Linnakangas's avatar
      Allocate enough shared string memory for stats of auxiliary processes. · 811969b2
      Heikki Linnakangas authored
      This fixes a bug whereby the st_appname, st_clienthostname, and
      st_activity_raw fields for auxiliary processes point beyond the end of
      their respective shared memory segments. As a result, the application_name
      of a backend might show up as the client hostname of an auxiliary process.
      
      Backpatch to v10, where this bug was introduced, when the auxiliary
      processes were added to the array.
      
      Author: Edmund Horner
      Reviewed-by: Michael Paquier
      Discussion: https://www.postgresql.org/message-id/CAMyN-kA7aOJzBmrYFdXcc7Z0NmW%2B5jBaf_m%3D_-77uRNyKC9r%3DA%40mail.gmail.com
      811969b2
    • Heikki Linnakangas's avatar
      Make local copy of client hostnames in backend status array. · a820b4c3
      Heikki Linnakangas authored
      The other strings, application_name and query string, were snapshotted to
      local memory in pgstat_read_current_status(), but we forgot to do that for
      client hostnames. As a result, the client hostname would appear to change in
      the local copy, if the client disconnected.
      
      Backpatch to all supported versions.
      
      Author: Edmund Horner
      Reviewed-by: Michael Paquier
      Discussion: https://www.postgresql.org/message-id/CAMyN-kA7aOJzBmrYFdXcc7Z0NmW%2B5jBaf_m%3D_-77uRNyKC9r%3DA%40mail.gmail.com
      a820b4c3
    • Alvaro Herrera's avatar
      Fix ALTER TABLE .. ATTACH PARTITION ... DEFAULT · 72cf7f31
      Alvaro Herrera authored
      If the table being attached contained values that contradict the default
      partition's partition constraint, it would fail to complain, because
      CommandCounterIncrement changes in 4dba331c coupled with some bogus
      coding in the existing ValidatePartitionConstraints prevented the
      partition constraint from being validated after all -- or rather, it
      caused to constraint to become an empty one, always succeeding.
      
      Fix by not re-reading the OID of the default partition in
      ATExecAttachPartition.  To forestall similar problems, revise the
      existing code:
      * rename routine from ValidatePartitionConstraints() to
        QueuePartitionConstraintValidation, to better represent what it
        actually does.
      * add an Assert() to make sure that when queueing a constraint for a
        partition we're not overwriting a constraint previously queued.
      * add an Assert() that we don't try to invoke the special-purpose
        validation of the default partition when attaching the default
        partition itself.
      
      While at it, change some loops to obtain partition OIDs from
      partdesc->oids rather than find_all_inheritors; reduce the lock level
      of partitions being scanned from AccessExclusiveLock to ShareLock;
      rewrite QueuePartitionConstraintValidation in a recursive fashion rather
      than repetitive.
      
      Author: Álvaro Herrera.  Tests written by Amit Langote
      Reported-by: Rushabh Lathia
      Diagnosed-by: Kyotaro HORIGUCHI, who also provided the initial fix.
      Reviewed-by: Kyotaro HORIGUCHI, Amit Langote, Jeevan Ladhe
      Discussion: https://postgr.es/m/CAGPqQf0W+v-Ci_qNV_5R3A=Z9LsK4+jO7LzgddRncpp_rrnJqQ@mail.gmail.com
      72cf7f31
    • Tom Lane's avatar
      Invoke submake-generated-headers during "make check", too. · cee83ef4
      Tom Lane authored
      The MAKELEVEL hack to prevent submake-generated-headers from doing
      anything in child make runs means that we have to explicitly invoke
      it at top level for "make check", too, in case somebody proceeds
      directly to that without an explicit "make all".  (I think this
      usage had parallel-make hazards even before the addition of more
      generated headers; but it was totally broken as of 3b8f6e75.)
      
      Out of paranoia, force the submake-libpq target to depend on
      submake-generated-headers, too.  This seems to not be absolutely
      necessary today, but it's not really saving us anything to omit
      the ordering dependency, and it'll likely break someday without it.
      
      Discussion: https://postgr.es/m/20180411103930.GB31461@momjian.us
      cee83ef4
    • Teodor Sigaev's avatar
      Temporary revert 5c6110c6 · 92899992
      Teodor Sigaev authored
      It discovers one more bug in CompareIndexInfo(), should be fixed first.
      92899992
    • Peter Eisentraut's avatar
      Fix clashing function names between jsonb_plperl and jsonb_plperlu · 651cb909
      Peter Eisentraut authored
      This prevented them from being installed at the same time.
      
      Author: Dagfinn Ilmari Mannsåker <ilmari@ilmari.org>
      651cb909
    • Teodor Sigaev's avatar
      Fix interference between cavering indexes and partitioned tables · 5c6110c6
      Teodor Sigaev authored
      The bug is caused due to the original IndexStmt that DefineIndex receives
      being overwritten when processing the INCLUDE columns. Use separate list of
      index params to propagate to child tables. Add tests covering this case.
      
      Amit Langote and Alexander Korotkov.
      5c6110c6
    • Peter Eisentraut's avatar
      doc: Add more information about logical replication privileges · f1f537cb
      Peter Eisentraut authored
      In particular, the requirement to have SELECT privilege for the initial
      table copy was previously not documented.
      
      Author: Shinoda, Noriyoshi <noriyoshi.shinoda@hpe.com>
      f1f537cb
    • Peter Eisentraut's avatar
      doc: Fix typos in pgbench documentation · 036ca6f7
      Peter Eisentraut authored
      Author: Fabien COELHO <coelho@cri.ensmp.fr>
      Reviewed-by: default avatarEdmund Horner <ejrh00@gmail.com>
      036ca6f7
  4. 10 Apr, 2018 7 commits
    • Andrew Dunstan's avatar
      minor comment fixes in nbtinsert.c · 8716b264
      Andrew Dunstan authored
      8716b264
    • Tom Lane's avatar
      Fix incorrect close() call in dsm_impl_mmap(). · 231bcd08
      Tom Lane authored
      One improbable error-exit path in this function used close() where
      it should have used CloseTransientFile().  This is unlikely to be
      hit in the field, and I think the consequences wouldn't be awful
      (just an elog(LOG) bleat later).  But a bug is a bug, so back-patch
      to 9.4 where this code came in.
      
      Pan Bian
      
      Discussion: https://postgr.es/m/152056616579.4966.583293218357089052@wrigleys.postgresql.org
      231bcd08
    • Andrew Dunstan's avatar
      Adjustments to the btree fastpath optimization. · 074251db
      Andrew Dunstan authored
      This optimization was introduced in commit 2b272734. The changes include
      some additional comments and documentation, and also these more
      substantive changes:
      . ensure the optimization is only applied on the leaf node of a tree
      whose root is on level 2 or more. It's of little value on small trees.
      . Delay calling RelationSetTargetBlock() until after the critical
      section of _bt_insertonpg
      . ensure the optimization is also applied to unlogged tables.
      
      Pavan Deolasee and Peter Geoghegan with some very light editing from me.
      
      Discussion: https://postgr.es/m/CABOikdO8jhRarNC60nZLktZYhxt+TK8z_V97+Ny499YQdyAfug@mail.gmail.com
      074251db
    • Tom Lane's avatar
      Put back parallel-safety guards in plpython and src/test/regress/. · 31f1f0bb
      Tom Lane authored
      I'd hoped that commit 3b8f6e75 was sufficient to ensure parallel safety
      even when a build started in a subdirectory requires rebuilding of
      generated headers.  This isn't so, because making submake-generated-headers
      a prerequisite of "all" isn't enough to ensure it's completed before
      starting on "all"'s other prerequisites.  The explicit dependencies we put
      on the recursive make targets ensure safe ordering before we recurse into
      child directories, but they don't protect targets to be made in the current
      directory.  Hence, put back some ordering dependencies in directories that
      we've traditionally expected to be starting points for "standalone" builds,
      to wit src/pl/plpython and src/test/regress.  (The former needs this in
      order to minimize the work involved in building for both python 2 and
      python 3; the latter to support packagings that make the regression tests
      available for out-of-build-tree execution.)  Adjust some other dependencies
      so that these two cases work correctly even at high -j settings.
      
      I'm not terribly happy with this partial solution, but I don't see a
      way to do better without massive makefile restructuring, which we surely
      aren't doing at this point in the development cycle.  In any case, it's
      little if any worse than what we had in prior releases.
      
      Discussion: https://postgr.es/m/1523353963.8169.26.camel@gunduz.org
      31f1f0bb
    • Alvaro Herrera's avatar
      Fix IndexOnlyScan counter for heap fetches in parallel mode · 15a8f8ca
      Alvaro Herrera authored
      The HeapFetches counter was using a simple value in IndexOnlyScanState,
      which fails to propagate values from parallel workers; so the counts are
      wrong when IndexOnlyScan runs in parallel.  Move it to Instrumentation,
      like all the other counters.
      
      While at it, change INSERT ON CONFLICT conflicting tuple counter to use
      the new ntuples2 instead of nfiltered2, which is a blatant misuse.
      
      Discussion: https://postgr.es/m/20180409215851.idwc75ct2bzi6tea@alvherre.pgsql
      15a8f8ca
    • Tom Lane's avatar
      Fix pgxs.mk to not try to build generated headers in external builds. · 1a40485a
      Tom Lane authored
      Per Julien Rouhaud and the buildfarm.  This is not quite Julien's
      patch: there's no need to lobotomize this build rule when building
      contrib modules in-tree, so set NO_GENERATED_HEADERS only if PGXS.
      
      In passing, also set NO_TEMP_INSTALL in external builds.  This doesn't
      seem to be fixing any live bug, because "make check" in an external
      build just produces the expected error message without first trying to
      make a temp install ... but it's far from obvious why it doesn't, so
      this change seems like good future-proofing.
      
      Julien Rouhaud and Tom Lane
      
      Discussion: https://postgr.es/m/CAOBaU_YH=g68opbbMk8is3jNwhoXGa8ckRSre1nx0Obe1C7i-Q@mail.gmail.com
      1a40485a
    • Heikki Linnakangas's avatar
      Fix comment on B-tree insertion fastpath condition. · 29d7ebf5
      Heikki Linnakangas authored
      The comment earlier in the function correctly states "and the insertion
      key is strictly greater than the first key in this page". That is what
      we check here, not "greater than or equal".
      29d7ebf5
  5. 09 Apr, 2018 9 commits
    • Tom Lane's avatar
      Fix partial-build problems introduced by having more generated headers. · 3b8f6e75
      Tom Lane authored
      Commit 372728b0 created some problems for usages like building a
      subdirectory without having first done "make all" at the top level,
      or for proceeding directly to "make install" without "make all".
      The only reasonably clean way to fix this seems to be to force the
      submake-generated-headers rule to fire in *any* "make all" or "make
      install" command anywhere in the tree.  To avoid lots of redundant work,
      as well as parallel make jobs possibly clobbering each others' output, we
      still need to be sure that the rule fires only once in a recursive build.
      For that, adopt the same MAKELEVEL hack previously used for "temp-install".
      But try to document it a bit better.
      
      The submake-errcodes mechanism previously used in src/port/ and src/common/
      is subsumed by this, so we can get rid of those special cases.  It was
      inadequate for src/common/ anyway after the aforesaid commit, and it always
      risked parallel attempts to build errcodes.h.
      
      Discussion: https://postgr.es/m/E1f5FAB-0006LU-MB@gemulon.postgresql.org
      3b8f6e75
    • Alvaro Herrera's avatar
      Fix incorrect logic for choosing the next Parallel Append subplan · 468abb8f
      Alvaro Herrera authored
      In 499be013 support for pruning unneeded Append subnodes was added.
      The logic in that commit was not correctly checking if the next subplan
      was in fact a valid subplan. This could cause parallel workers processes
      to be given a subplan to work on which didn't require any work.
      
      Per code review following an otherwise unexplained regression failure in
      buildfarm member Pademelon.  (We haven't been able to reproduce the
      failure, so this is a bit of a blind fix in terms of whether it'll
      actually fix it; but it is a clear bug nonetheless).
      
      In passing, also add a comment to explain what first_partial_plan means.
      
      Author: David Rowley
      Discussion: https://postgr.es/m/CAKJS1f_E5r05hHUVG3UmCQJ49DGKKHtN=SHybD44LdzBn+CJng@mail.gmail.com
      468abb8f
    • Magnus Hagander's avatar
      Silence some warnings in TAP tests · d7754822
      Magnus Hagander authored
      Author: Michael Paquier
      d7754822
    • Magnus Hagander's avatar
      Make sure pg_rewind can't run as root · 5d5aedda
      Magnus Hagander authored
      Previously a warning was printed, but the tool actually kept running
      even when running as root. This is something we definitely want to
      prevent, but since this means a behavior change, not backpatching.
      
      Author: Michael Paquier
      5d5aedda
    • Tom Lane's avatar
      Reduce chattiness of genbki.pl and Gen_fmgrtab.pl. · a65e17bd
      Tom Lane authored
      Make these scripts emit just one log message when they run, not one
      per output file.  The latter is way too verbose in the wake of
      commit 372728b0.  The specific wording used is what already existed
      in the MSVC scripts.
      
      John Naylor
      
      Discussion: https://postgr.es/m/11103.1523208822@sss.pgh.pa.us
      a65e17bd
    • Tom Lane's avatar
      Make reformat_dat_file.pl preserve all blank lines. · 2cdf359f
      Tom Lane authored
      In its original form, reformat_dat_file.pl smashed consecutive blank
      lines to a single blank line, which was helpful for mopping up excess
      whitespace during the bootstrap data format conversion.  But going
      forward, there seems little reason to do that; if developers want to
      put in multiple blank lines, let 'em.  This makes it conform to the
      documentation I (tgl) wrote, too.
      
      In passing, clean up some sloppy markup choices in bki.sgml.
      
      John Naylor
      
      Discussion: https://postgr.es/m/28827.1523039259@sss.pgh.pa.us
      2cdf359f
    • Tom Lane's avatar
      Further cleanup of client dependencies on src/include/catalog headers. · af1a9491
      Tom Lane authored
      In commit 9c0a0de4, I'd failed to notice that catalog/catalog.h
      should also be considered a frontend-unsafe header, because it includes
      (and needs) the full form of pg_class.h, not to mention relcache.h.
      However, various frontend code was depending on it to get
      TABLESPACE_VERSION_DIRECTORY, so refactoring of some sort is called for.
      
      The cleanest answer seems to be to move TABLESPACE_VERSION_DIRECTORY,
      as well as the OIDCHARS symbol, to common/relpath.h.  Do that, and mop up
      inclusions as necessary.  (I found that quite a few current users of
      catalog/catalog.h don't seem to need it at all anymore, apparently as a
      result of the refactorings that created common/relpath.[hc].  And
      initdb.c needed it only as a route to pg_class_d.h.)
      
      Discussion: https://postgr.es/m/6629.1523294509@sss.pgh.pa.us
      af1a9491
    • Magnus Hagander's avatar
      catversion bump for online-checksums revert · f5543d47
      Magnus Hagander authored
      Lack thereof pointed out by Tom Lane.
      f5543d47
    • Magnus Hagander's avatar
      Revert "Allow on-line enabling and disabling of data checksums" · a228cc13
      Magnus Hagander authored
      This reverts the backend sides of commit 1fde38be.
      I have, at least for now, left the pg_verify_checksums tool in place, as
      this tool can be very valuable without the rest of the patch as well,
      and since it's a read-only tool that only runs when the cluster is down
      it should be a lot safer.
      a228cc13