1. 19 12月, 2009 8 次提交
    • T
      Adjust some more places in the documentation to match the fact that · c43d26c1
      Tom Lane 提交于
      plpgsql is now installed by default.
      c43d26c1
    • S
      Allow read only connections during recovery, known as Hot Standby. · efc16ea5
      Simon Riggs 提交于
      Enabled by recovery_connections = on (default) and forcing archive recovery using a recovery.conf. Recovery processing now emulates the original transactions as they are replayed, providing full locking and MVCC behaviour for read only queries. Recovery must enter consistent state before connections are allowed, so there is a delay, typically short, before connections succeed. Replay of recovering transactions can conflict and in some cases deadlock with queries during recovery; these result in query cancellation after max_standby_delay seconds have expired. Infrastructure changes have minor effects on normal running, though introduce four new types of WAL record.
      
      New test mode "make standbycheck" allows regression tests of static command behaviour on a standby server while in recovery. Typical and extreme dynamic behaviours have been checked via code inspection and manual testing. Few port specific behaviours have been utilised, though primary testing has been on Linux only so far.
      
      This commit is the basic patch. Additional changes will follow in this release to enhance some aspects of behaviour, notably improved handling of conflicts, deadlock detection and query cancellation. Changes to VACUUM FULL are also required.
      
      Simon Riggs, with significant and lengthy review by Heikki Linnakangas, including streamlined redesign of snapshot creation and two-phase commit.
      
      Important contributions from Florian Pflug, Mark Kirkwood, Merlin Moncure, Greg Stark, Gianni Ciolli, Gabriele Bartolini, Hannu Krosing, Robert Haas, Tatsuo Ishii, Hiroyuki Yamada plus support and feedback from many other community members.
      efc16ea5
    • B
      binary migration: pg_migrator · 78a09145
      Bruce Momjian 提交于
      Add comments about places where system oids have to be preserved for
      binary migration.
      78a09145
    • R
      Fix a few typos in the latest 8.5alpha3 release notes. · 2e9468f2
      Robert Haas 提交于
      2e9468f2
    • P
      2692274d
    • T
      Fix link that doesn't work in standalone INSTALL document. · b35b16e6
      Tom Lane 提交于
      b35b16e6
    • B
      Install server-side language PL/pgSQL by default. · 96c102fe
      Bruce Momjian 提交于
      96c102fe
    • T
      Force the TZ environment variable to be set during initdb. This is to · be3a24de
      Tom Lane 提交于
      short-circuit the rather expensive identify_system_timezone() procedure,
      which we have no real need for during initdb since nothing done here depends
      on the timezone setting.  Since we launch quite a few standalone backends
      during the initdb sequence, this adds up to a significant savings, and seems
      worth doing to save developer time even though it will hardly matter to end
      users.  Per my report today on pgsql-hackers.
      be3a24de
  2. 17 12月, 2009 7 次提交
    • R
      Improve documentation for pg_largeobject changes. · f5fd651e
      Robert Haas 提交于
      Rewrite the documentation in more idiomatic English, and in the process make
      it somewhat more succinct.  Move the discussion of specific large object
      privileges out of the "server-side functions" section, where it certainly
      doesn't belong, and into "implementation features".  That might not be
      exactly right either, but it doesn't seem worth creating a new section for
      this amount of information. Fix a few spelling and layout problems, too.
      f5fd651e
    • M
      Reverting accidently commited changes. · 36d192ad
      Michael Meskes 提交于
      36d192ad
    • P
      Don't unblock SIGQUIT in the SIGQUIT handler · d6de4309
      Peter Eisentraut 提交于
      This was possibly linked to a deadlock-like situation in glibc syslog code
      invoked by the ereport call in quickdie().  In any case, a signal handler
      should not unblock its own signal unless there is a specific reason to.
      d6de4309
    • P
      If there is no sigdelset(), define it as a macro. · b63b967a
      Peter Eisentraut 提交于
      This removes some duplicate code that recreated the identical workaround
      when the newer signal API is missing.
      b63b967a
    • T
      Avoid a premature coercion failure in transformSetOperationTree() when · 52fc0075
      Tom Lane 提交于
      presented with an UNKNOWN-type Var, which can happen in cases where an
      unknown literal appeared in a subquery.  While many such cases will fail
      later on anyway in the planner, there are some cases where the planner is
      able to flatten the query and replace the Var by the constant before it has
      to coerce the union column to the final type.  I had added this check in 8.4
      to provide earlier/better error detection, but it causes a regression for
      some cases that worked OK before.  Fix by not making the check if the input
      node is UNKNOWN type and not a Const or Param.  If it isn't going to work,
      it will fail anyway at plan time, with the only real loss being inability to
      provide an error cursor.  Per gripe from Britt Piehler.
      
      In passing, rename a couple of variables to remove confusion from an
      inner scope masking the same variable names in an outer scope.
      52fc0075
    • R
      Several fixes for EXPLAIN (FORMAT YAML), plus one for EXPLAIN (FORMAT JSON). · ff499613
      Robert Haas 提交于
      ExplainSeparatePlans() was busted for both JSON and YAML output - the present
      code is a holdover from the original version of my machine-readable explain
      patch, which didn't have the grouping_stack machinery.  Also, fix an odd
      distribution of labor between ExplainBeginGroup() and ExplainYAMLLineStarting()
      when marking lists with "- ", with each providing one character.  This broke
      the output format for multi-query statements.  Also, fix ExplainDummyGroup()
      for the YAML output format.
      
      Along the way, make the YAML format use escape_yaml() in situations where the
      JSON format uses escape_json().  Right now, it doesn't matter because all the
      values are known not to need escaping, but it seems safer this way.  Finally,
      I added some comments to better explain what the YAML output format is doing.
      
      Greg Sabino Mullane reported the issues with multi-query statements.
      Analysis and remaining cleanups by me.
      ff499613
    • M
      Remove spurious '22' that clearly shouldn't be there. · 3dfe7e8e
      Magnus Hagander 提交于
      David E. Wheeler
      3dfe7e8e
  3. 16 12月, 2009 5 次提交
  4. 15 12月, 2009 4 次提交
  5. 14 12月, 2009 2 次提交
    • T
      Fix a bug introduced when set-returning SQL functions were made inline-able: · a620d500
      Tom Lane 提交于
      we have to cope with the possibility that the declared result rowtype contains
      dropped columns.  This fails in 8.4, as per bug #5240.
      
      While at it, be more paranoid about inserting binary coercions when inlining.
      The pre-8.4 code did not really need to worry about that because it could not
      inline at all in any case where an added coercion could change the behavior
      of the function's statement.  However, when inlining a SRF we allow sorting,
      grouping, and set-ops such as UNION.  In these cases, modifying one of the
      targetlist entries that the sort/group/setop depends on could conceivably
      change the behavior of the function's statement --- so don't inline when
      such a case applies.
      a620d500
    • I
      Additional fixes for large object access control. · 84f910a7
      Itagaki Takahiro 提交于
      Use pg_largeobject_metadata.oid instead of pg_largeobject.loid
      to enumerate existing large objects in pg_dump, pg_restore, and
      contrib modules.
      84f910a7
  6. 13 12月, 2009 2 次提交
    • M
      Allow LDAP authentication to operate in search+bind mode, meaning it · 0182d6f6
      Magnus Hagander 提交于
      does a search for the user in the directory first, and then binds with
      the DN found for this user.
      
      This allows for LDAP logins in scenarios where the DN of the user cannot
      be determined simply by prefix and suffix, such as the case where different
      users are located in different containers.
      
      The old way of authentication can be significantly faster, so it's kept
      as an option.
      
      Robert Fleming and Magnus Hagander
      0182d6f6
    • T
      Fix integer-to-bit-string conversions to handle the first fractional byte · a4e035b2
      Tom Lane 提交于
      correctly when the output bit width is wider than the given integer by
      something other than a multiple of 8 bits.
      
      This has been wrong since I first wrote that code for 8.0 :-(.  Kudos to
      Roman Kononov for being the first to notice, though I didn't use his
      patch.  Per bug #5237.
      a4e035b2
  7. 12 12月, 2009 3 次提交
    • R
      Export ExplainBeginOutput() and ExplainEndOutput() for auto_explain. · 02490d46
      Robert Haas 提交于
      Without these functions, anyone outside of explain.c can't actually use
      ExplainPrintPlan, because the ExplainState won't be initialized properly.
      The user-visible result of this was a crash when using auto_explain with
      the JSON output format.
      
      Report by Euler Taveira de Oliveira.  Analysis by Tom Lane.  Patch by me.
      02490d46
    • T
      Arrange to generate different random sequences in the different child · 6b45e3b7
      Tom Lane 提交于
      processes of a pgbench run, when we are using -j > 1 and are emulating
      threads via fork().  Otherwise the children all inherit the same random
      sequence state and produce the same random-number sequence.
      
      In the threaded case the different threads will share one RNG state, so
      they will produce different subsets of one sequence, which is maybe more
      correlated than a purist would like but will not be "the same".  So we
      leave that case alone.
      
      First noticed by Takahiro Itagaki, and is also part of the explanation
      for the pgbench misbehavior recently reported by Jaime Casanova.
      6b45e3b7
    • T
      Ensure that the result tuple of an EvalPlanQual cycle gets materialized · d8e511fa
      Tom Lane 提交于
      before we zap the input tuple.  Otherwise, pass-by-reference columns of
      the result slot are likely to contain just references to the input
      tuple, leading to big trouble if the pfree'd space is reused.  Per
      trouble report from Jaime Casanova.  This is a new bug in the recent
      rewrite of EvalPlanQual, so nothing to back-patch.
      d8e511fa
  8. 11 12月, 2009 4 次提交
  9. 10 12月, 2009 5 次提交
    • P
      Add init[db] option to pg_ctl · a37b001b
      Peter Eisentraut 提交于
      pg_ctl gets a new mode that runs initdb.  Adjust the documentation a bit to
      not assume that initdb is the only way to run database cluster initialization.
      But don't replace initdb as the canonical way.
      
      Author: Zdenek Kotala <Zdenek.Kotala@Sun.COM>
      a37b001b
    • R
      Fix levenshtein with costs. The previous code multiplied by the cost in only · da076414
      Robert Haas 提交于
      3 of the 7 relevant locations.
      
      Marcin Mank, slightly adjusted by me.
      da076414
    • T
      03d7b064
    • T
      Prevent indirect security attacks via changing session-local state within · 62aba765
      Tom Lane 提交于
      an allegedly immutable index function.  It was previously recognized that
      we had to prevent such a function from executing SET/RESET ROLE/SESSION
      AUTHORIZATION, or it could trivially obtain the privileges of the session
      user.  However, since there is in general no privilege checking for changes
      of session-local state, it is also possible for such a function to change
      settings in a way that might subvert later operations in the same session.
      Examples include changing search_path to cause an unexpected function to
      be called, or replacing an existing prepared statement with another one
      that will execute a function of the attacker's choosing.
      
      The present patch secures VACUUM, ANALYZE, and CREATE INDEX/REINDEX against
      these threats, which are the same places previously deemed to need protection
      against the SET ROLE issue.  GUC changes are still allowed, since there are
      many useful cases for that, but we prevent security problems by forcing a
      rollback of any GUC change after completing the operation.  Other cases are
      handled by throwing an error if any change is attempted; these include temp
      table creation, closing a cursor, and creating or deleting a prepared
      statement.  (In 7.4, the infrastructure to roll back GUC changes doesn't
      exist, so we settle for rejecting changes of "search_path" in these contexts.)
      
      Original report and patch by Gurjeet Singh, additional analysis by
      Tom Lane.
      
      Security: CVE-2009-4136
      62aba765
    • M
      Add notes about updating disk and shared memory size information in the · 7aeaa97d
      Magnus Hagander 提交于
      documentation when doing new major release.
      7aeaa97d