1. 25 Oct, 2019 4 commits
    • Tom Lane's avatar
      Reset statement_timeout between queries of a multi-query string. · 2b2bacdc
      Tom Lane authored
      Historically, we started the timer (if StatementTimeout > 0) at the
      beginning of a simple-Query message and usually let it run until the
      end, so that the timeout limit applied to the entire query string,
      and intra-string changes of the statement_timeout GUC had no effect.
      But, confusingly, a COMMIT within the string would reset the state
      and allow a fresh timeout cycle to start with the current setting.
      
      Commit f8e5f156 changed the behavior of statement_timeout for extended
      query protocol, and as an apparently-unintended side effect, a change in
      the statement_timeout GUC during a multi-statement simple-Query message
      might have an effect immediately --- but only if it was going from
      "disabled" to "enabled".
      
      This is all pretty confusing, not to mention completely undocumented.
      Let's change things so that the timeout is always reset between queries
      of a multi-query string, whether they're transaction control commands
      or not.  Thus the active timeout setting is applied to each query in
      the string, separately.  This costs a few more cycles if statement_timeout
      is active, but it provides much more intuitive behavior, especially if one
      changes statement_timeout in one of the queries of the string.
      
      Also, add something to the documentation to explain all this.
      
      Per bug #16035 from Raj Mohite.  Although this is a bug fix, I'm hesitant
      to back-patch it; conceivably somebody has worked out the old behavior
      and is depending on it.  (But note that this change should make the
      behavior less restrictive in most cases, since the timeout will now
      be applied to shorter segments of code.)
      
      Discussion: https://postgr.es/m/16035-456e6e69ebfd4374@postgresql.org
      2b2bacdc
    • Amit Kapila's avatar
      Revert part of commit dddf4cdc. · c114229c
      Amit Kapila authored
      The commit dddf4cdc tries to ensure that the Postgres header file
      inclusions are in order based on their ASCII value.  However, in one of
      the case there is a header file dependency due to which we can't maintain
      such order.
      
      Author: Amit Kapila
      Discussion: https://postgr.es/m/E1iNpHW-000855-1u@gemulon.postgresql.org
      c114229c
    • Amit Kapila's avatar
      Make the order of the header file includes consistent in non-backend modules. · dddf4cdc
      Amit Kapila authored
      Similar to commit 7e735035, this commit makes the order of header file
      inclusion consistent for non-backend modules.
      
      In passing, fix the case where we were using angle brackets (<>) for the
      local module includes instead of quotes ("").
      
      Author: Vignesh C
      Reviewed-by: Amit Kapila
      Discussion: https://postgr.es/m/CALDaNm2Sznv8RR6Ex-iJO6xAdsxgWhCoETkaYX=+9DW3q0QCfA@mail.gmail.com
      dddf4cdc
    • Michael Paquier's avatar
      Handle interrupts within a transaction context in REINDEX CONCURRENTLY · 8270a0d9
      Michael Paquier authored
      Phases 2 (building the new index) and 3 (validating the new index)
      checked for interrupts outside a transaction context, having as
      consequence to not release session-level locks taken on the parent
      relation and the old and new indexes processed.  This could for example
      be triggered with statement_timeout and a bad timing, and would issue
      confusing error messages when shutting down the session still holding
      the locks (note that an assertion failure would be triggered first), on
      top of more issues with concurrent sessions trying to take a lock that
      would interfere with the SHARE UPDATE EXCLUSIVE locks hold here.
      
      This moves all the interruption checks inside a transaction context.
      Note that I have manually tested all interruptions to make sure that
      invalid indexes can be cleaned up properly.  Partition indexes still
      have issues on their own with some missing dependency handling, which
      will be dealt with in a follow-up patch.
      
      Reported-by: Justin Pryzby
      Author: Michael Paquier
      Discussion: https://postgr.es/m/20191013025145.GC4475@telsasoft.com
      Backpatch-through: 12
      8270a0d9
  2. 24 Oct, 2019 3 commits
  3. 23 Oct, 2019 6 commits
  4. 22 Oct, 2019 2 commits
  5. 21 Oct, 2019 9 commits
  6. 20 Oct, 2019 1 commit
  7. 19 Oct, 2019 5 commits
  8. 18 Oct, 2019 5 commits
  9. 17 Oct, 2019 3 commits
  10. 16 Oct, 2019 2 commits