Features Download
From: David Fetter <david <at> fetter.org>
Subject: == PostgreSQL Weekly News - October 13 2013 ==
Newsgroups: gmane.comp.db.postgresql.announce
Date: Monday 14th October 2013 05:23:42 UTC (over 2 years ago)
== PostgreSQL Weekly News - October 13 2013 ==

PostgreSQL 9.3.1, 9.2.5, 9.1.10, 9.0.14, and 8.4.18 bug fix releases
are out.  Upgrade at the next scheduled down time unless you are
directly affected by the issues below.

The second Commitfest of the 9.4 cycle will end at end-of-day October
15, 2013.  Review those patches!

The international CfP for Ecudorian PostgreSQL Day, part of the
International Meeting of Free Software in Quito, Ecuador, is open.
Write ecpug  postgresql  org.  Details (Spanish language)

== PostgreSQL Product News ==

pgAdmin3 v1.18.1 a multi-platform stand-alone GUI administration tool,

PgToolkit v1.0.0, which includes a tool to reduce table bloat in
PostgreSQL, released

== PostgreSQL Jobs for October ==


== PostgreSQL Local ==

The Italian PGDay (PGDay.IT) will be held on October the 25th in
Prato, Tuscany, Italy, at Monash University Center.
To register to the event or get information about the accepted talks
and schedule please see the official web site: http://2013.pgday.it

The PostgreSQL Conference China for 2013 will be held October 26-27,
2013 in Hangzhou.  Chinese language information here:

pgconf.EU 2013 will be held on Oct 29-Nov 1, 2013 at the Conrad Hotel
in downtown Dublin, Ireland.  Registration is open.

PGConf.DE 2013 will be held November 8th, 2013, at the Rhineland
Industrial Museum in Oberhausen.  The CfP is open through September
15, 2013.

The fourth edition of the Argentinian PostgreSQL Day will be held on
November 14 2013 in Buenos Aires, Argentina.

PGDay Cuba will be in November, 2013.

== PostgreSQL in the News ==

Planet PostgreSQL: http://planet.postgresql.org/

PostgreSQL Weekly News is brought to you this week by David Fetter

Submit news and announcements by Sunday at 3:00pm Pacific time.
Please send English language ones to [email protected], German language
to [email protected], Italian language to [email protected]  Spanish language
to [email protected]

== Applied Patches ==

Kevin Grittner pushed:

- Eliminate xmin from hash tag for predicate locks on heap tuples.  If
  a tuple was frozen while its predicate locks mattered, read-write
  dependencies could be missed, resulting in failure to detect
  conflicts which could lead to anomalies in committed serializable
  transactions.  This field was added to the tag when we still thought
  that it was necessary to carry locks forward to a new version of an
  updated row.  That was later proven to be unnecessary, which allowed
  simplification of the code, but elimination of xmin from the tag was
  missed at the time.  Per report and analysis by Heikki Linnakangas.
  Backpatch to 9.1.

- Allow drop-index-concurrently-1 test to run at any isolation level.
  It previously reported failure at REPEATABLE READ and SERIALIZABLE
  transaction isolation levels for make installcheck.

- Add record_image_ops opclass for matview concurrent refresh.
  containing a column of a type without a default btree operator
  class.  It also did not produce results consistent with a non-
  concurrent REFRESH or a normal view if any column was of a type
  which allowed user-visible differences between values which compared
  as equal according to the type's default btree opclass.  Concurrent
  matview refresh was modified to use the new operators to solve these
  problems.  Documentation was added for record comparison, both for
  the default btree operator class for record, and the newly added
  operators.  Regression tests now check for proper behavior both for
  a matview with a box column and a matview containing a citext
  column.  Reviewed by Steve Singer, who suggested some of the doc

- Fix bug in record_image_ops on big endian machines.  The buildfarm
  pointed out the problem.  Fix based on suggestion by Robert Haas.

- Fix several possibly non-portable gaffs in record_image_ops.  Sparc
  machines in the buildfarm were made happy by the previous fix, but
  PowerPC machines still are still failing.  Hopefully this will cure

Robert Haas pushed:

- plpgsql: Add new option print_strict_params.  This option provides
  more detailed error messages when STRICT is used and the number of
  rows returned is not one.  Marko Tiikkaja, reviewed by Ian Lawrence

- Make DISCARD SEQUENCES also discard the last used sequence.
  Otherwise, we access already-freed memory.  Oops.  Report by Michael
  Paquier.  Fix by me.

- Allow dynamic allocation of shared memory segments.  Patch by myself
  and Amit Kapila.  Design help from Noah Misch.  Review by Andres

- Fix incorrect use of shm_unlink where unlink should be used.  Per

- initdb: Select working dynamic shared memory implementation.  If
  POSIX shared memory is supported and works, we prefer it.
  Otherwise, we prefer System V, except on Windows, where we use the
  implementation specific to that platform.

Peter Eisentraut pushed:

- Translation updates

- Stamp 9.3.1, 9.2.5, 9.1.10, 9.0.14, 8.4.18.

- Revive line type.  Change the input/output format to {A,B,C}, to
  match the internal representation.  Complete the implementations of
  line_in, line_out, line_recv, line_send.  Remove comments and error
  messages about the line type not being implemented.  Add regression
  tests for existing line operators and functions.  Reviewed-by: rui
  hua <[email protected]> Reviewed-by: Álvaro Herrera
   Reviewed-by: Jeevan Chalke
  <[email protected]>

- pg_upgrade: Split off pg_fatal() from pg_log().  This allows
  decorating pg_fatal() with noreturn compiler hints, leading to
  better diagnostics.  Reviewed-by: Marko Tiikkaja 

- Update regression tests for line type patch.  Erroneously omitted in

- Replace duplicate_oids with Perl implementation.  It is more
  portable, more robust, and more readable.  From: Andrew Dunstan

- Remove maintainer-check target, fold into normal build.  make
  maintainer-check was obscure and rarely called in practice, and many
  breakages were missed.  Fold everything that make maintainer-check
  used to do into the normal build.  Specifically: Call duplicate_oids
  when genbki.pl is called.  Check for tabs in SGML files when the
  documentation is built.  Run msgfmt with the -c option during the
  regular build.  Add an additional configure check to see whether we
  are using the GNU version.  (make maintainer-check probably used to
  fail with non-GNU msgfmt.) Keep maintainer-check as around as phony
  target for the time being in case anyone is calling it.  But it
  won't do anything anymore.

- doc: Handle additional character entities for SGML/XML conversion

- doc: Fix table column number declaration

- doc: Move check-tabs target into html target.  The previous plan of
  having the check-tabs target a prerequisite of "all" and "distprep"
  caused make distcheck to fail because make -q distprep would never
  be satisfied.  Put check-tabs into the html target instead, so it is
  only called when a build actually happens.

- Tweak "line" test to avoid platform-specific floating-point output

- Add use of asprintf().  Add asprintf(), pg_asprintf(), and
  psprintf() to simplify string allocation and composition.
  Replacement implementations taken from NetBSD.  Reviewed-by: Álvaro
  Herrera  Reviewed-by: Asif Naeem

- Add asprintf.c.  Forgotten in

- Attempt to fix MSVC build for asprintf addition

- Translation updates to fix build failures.  Now that msgfmt is run
  with -c by default, older versions of gettext are complaining about
  the PO headers Last-Translator and Language-Team still having their
  default values.  Newer gettext versions fail to catch this because
  of a bug (https://savannah.gnu.org/bugs/?40261),
which is why this
  hasn't been noticed before.  Copy updated versions of affected
  translation files from the pgtranslations repository, were those
  files have been fixed.

Heikki Linnakangas pushed:

- Fix bugs in SSI tuple locking.  1. In heap_hot_search_buffer(), the
  PredicateLockTuple() call is passed wrong offset number.
  heapTuple->t_self is set to the tid of the first tuple in the chain
  that's visited, not the one actually being read.  2.
  CheckForSerializableConflictIn() uses the tuple's t_ctid field
  instead of t_self to check for exiting predicate locks on the tuple.
  If the tuple was updated, but the updater rolled back, t_ctid points
  to the aborted dead tuple.  Reported by Hannu Krosing. Backpatch to

- TYPEALIGN doesn't work on int64 on 32-bit platforms.  The TYPEALIGN
  macro, and the related ones like MAXALIGN, don't work with values
  larger than intptr_t, because TYPEALIGN casts the argument to
  intptr_t to do the arithmetic. That's not a problem when dealing
  with pointers or lengths or offsets related to pointers, but the
  XLogInsert scaling patch added a call to MAXALIGN with an XLogRecPtr
  argument.  To fix, add wider variants of the macros, called
  TYPEALIGN64 and MAXALIGN64, which are just like the existing
  variants but work with uint64 instead of intptr_t.  Report and patch
  by David Rowley, analysis by Andres Freund.

Bruce Momjian pushed:

- docs:  update release notes for 8.4.18, 9.0.14, 9.1.10, 9.2.5, 9.3.1

- Update instructions on creating minor release notes.

- Additional instructions on minor release note creation.

- Auto-tune effective_cache size to be 4x shared buffers

- unaccent:  mark unaccent() functions as immutable.  Suggestion from
  Pavel Stehule

- docs:  clarify references to md5 hash and md5 crypt in pgcrypto
  docs.  Suggestion from Richard Neill

- Update postgres.conf.sample for effective_cache_size's new default

- doc:  Fix typo in effective_cache_size patch

- Fix C comment in check_effective_cache_size()

- Move new effective_cache_size function.  Previously
  set_default_effective_cache_size() could not handle fork, non-fork,
  and bootstrap cases.

- Again move function where we set effective_cache_size's default

- Adjust the effective_cache_size default for standalone backends

- Centralize effective_cache_size default setting

- doc:  fix typo in release notes.  Backpatch through 8.4.  Per
  suggestion by Amit Langote

Andrew Dunstan pushed:

- json_typeof function.  Andrew Tipton.

Alvaro Herrera pushed:

- Use $(PERL) to invoke duplicate_oids.  Per buildfarm failure
  reported by smilodon

- Rework SSL renegotiation code.  The existing renegotiation code was
  home for several bugs: it might erroneously report that
  renegotiation had failed; it might try to execute another
  renegotiation while the previous one was pending; it failed to
  terminate the connection if the renegotiation never actually took
  place; if a renegotiation was started, the byte count was reset,
  even if the renegotiation wasn't completed (this isn't good from a
  security perspective because it means continuing to use a session
  that should be considered compromised due to volume of data
  transferred.) The new code is structured to avoid these pitfalls:
  renegotiation is started a little earlier than the limit has
  expired; the handshake sequence is retried until it has actually
  returned successfully, and no more than that, but if it fails too
  many times, the connection is closed.  The byte count is reset only
  when the renegotiation has succeeded, and if the renegotiation byte
  count limit expires, the connection is terminated.  This commit only
  touches the master branch, because some of the changes are
  controversial.  If everything goes well, a back-patch might be
  considered.  Per discussion started by message
  [email protected]

== Rejected Patches (for now) ==

No one was disappointed this week :-)

== Pending Patches ==

Dimitri Fontaine sent in another revision of a patch to implement PL
support for EVENT TRIGGERS.

SAKAMOTO Masahiko sent in another revision of a patch to enable
WAL-based fail-back without fresh backup.

Heikki Linnakangas sent in two more revisions of a patch to improve
GIN indexes by adding information to same.

Pavel Stehule sent in another revision of a patch to allow fast update
of arrays with fixed length in PL/pgsql.

Robert Haas sent in a patch to ensure that certain cases are always in
a transaction, incurring a cache hit if needed.

Andrew (RhodiumToad) Gierth sent in another revision of a patch to
implement UNNEST with multiple arguments and TABLE with multiple SRFs.

David Fetter sent in a patch to allow CREATE FOREIGN TABLE to take
LIKE as a parameter.

Kevin Grittner sent in another revision of a patch to fix the SSI
freezing bug.

Marc Cousin sent in a patch to fix an issue in contrib/lo triggers.

Andres Freund sent in another flock of patches intended to be
infrastructure for logical changeset generation.

Pavel Stehule sent in a patch to allow RAISE ... WHEN in PL/pgsql as
an alternative to the wordier IF [EXCEPTION_TYPE] THEN RAISE ... END
IF construct.

Michael Paquier sent in a patch to pre-fix some comments in the code
in preparation for REINDEX CONCURRENTLY.

Stefan Radomski sent in two more revisions of a patch to allow
reserving connections for replication roles, as distinct from those
reserved for superuser.

Antonin Houska sent in another revision of a patch to enable
throttling backups.

Mark Kirkwood sent in another revision of a patch to enable block

Sameer Thakur sent in a patch to add documentation for session_start
and introduced fields and corrects documentation for queryid to be
query_id in the pg_stat_statements view.

Heikki Linnakangas sent in another revision of a patch to extend the
CUBE extension support to points.

Pavel Stehule and Alvaro Herrera traded patches to implement a simple
date constructor for numeric values.

Hari Babu sent in a patch to fix an issue where vacuum is not
happening on a heavily modified big table even if the dead tuples are
more than configured threshold.  This was caused by the fact that the
number of dead tuples is set to zero and no accounting was made for
dead tuples created as the vacuum ran.

Michael Paquier sent in a patch to add worker_spi_terminate to

Peter Geoghegan sent in another revision of a patch to implement

Sent via pgsql-announce mailing list ([email protected])
To make changes to your subscription:
CD: 3ms