Der Originalartikel befindet sich unter:
== Wöchentlicher PostgreSQL Newsletter - 17. Januar 2010 ==
Das finale Commitfest für das kommende Release -- könnte es 9.0 sein?
-- hat begonnen. Es ist Zeit, all diese Patches zu reviewen, inkl.
Streaming Replikation. Schnelle Reviews bewirken, dass die Alpha
schneller kommt, und Alpha wird Beta und Beta öffnet den Weg zum
Release. Wenn du vorher noch keinen Patch reviewed hast, hier ist
Die Deutsche PostgreSQL User Gruppe hat einen Stand auf den
Chemnitzer Linuxtagen 2010 am 13. und 14. März 2010 in
Linuxfest Nordwest 2010 findet in Bellingham, Washington, USA am
24. und 25. April statt. Vortragsreihen, Stände und Sponsoring
== PostgreSQL Produkt Neuigkeiten ==
boxinfo Version 1.1.7
tail_n_mail 1.5.9, ein Log Monitor, ist erschienen.
== PostgreSQL 8.5 Feature der Woche ==
VACUUM FULL wurde derart verändert, dass immer alle Dateien neu für
die behandelte Tabelle und die Indexes erstellt werden. Dies basiert
auf dem alten CLUSTER Befehl und ist sowohl mehr effektiv als auch
mehr effizient. Die alte Funktionalität kann weiterhin mittels
VACUUM FULL INPLACE genutzt werden, aber ist nicht kompatibel mit
== PostgreSQL Tipp der Woche ==
Durch aktivieren der log_temp_files Option wird das Logging über die
Nutzung temporärer Dateien aktiviert und man kann monitoren, ob man
work_mem oder maintenance_work_mem in der Datenbank erhöhen muss.
== PostgreSQL Jobs im Januar ==
== PostgreSQL Lokal ==
PostgreSQL wird einen Stand auf der LinuxConf.AU Open Day in Wellington,
NZ, haben. Josh Berkus und Selena Deckelman werden die ganze Woche
auf der LCA vor Ort sein.
Der Call for Papers für East ist offen bis zum 30. Januar 2010.
PGDay Kuba 2010 findet vom 4.-6. Februar 2010 in La Havana an der
Universität für Wissenschaftliche Informatik statt. Teilnehmer aus
Kuba, der Dominikanischen Republik und Venezuela sind eingeladen.
FOSDEM 2010 findet am 6. und 7. Februar 2010 in Brüssel,
Die Deutsche PostgreSQL User Gruppe hat einen Stand in der
"Projekt Lounge" in Halle 2 auf der Cebit 2010 vom 02. bis zum 06.
März 2010 in Hannover, Deutschland.
Die Chemnitzer Linuxtage finden am 13. und 14. März in
Chemnitz, Deutschland statt.
Andreas (ads) Scherbaum hält einen Kurs "PostgreSQL im
Unternehmenseinsatz" an der VHS Magdeburg, Deutschland, vom 03. bis 07.
Mai 2010. Details unter:
PgCon 2010 findet vom 20.-21. Mai 2010 in Ottawa statt mit Tutorials
vorher am 18. und 19. Der Call for Papers ist offen!
Der Call for Proposals für die OSCON ist eröffnet. OSCON findet in
Portland, Oregon vom 19. bis 23. Juli 2010 statt.
== PostgreSQL in den News ==
Planet PostgreSQL: http://planet.postgresql.org/
Dieser wöchentliche PostgreSQL Newsletter wurde erstellt von David
Sende Neuigkeiten und Ankündigungen bis Sonntag, 15 Uhr Pazifischer
Zeit. Bitte sende englische Beiträge an email@example.com, deutsche an
firstname.lastname@example.org, italienische an email@example.com.
== Reviews ==
ITAGAKI Takahiro reviewed Pavel Stehule's patch to add USING to
OPEN...FOR EXECUTE in PL/pgsql and marked it "Ready for Committer."
Pavel Stehule reviewed Hitoshi Harada's patch to add more ROWS and
RANGE options to windowing functions.
Andreas Freund reviewed Simon Riggs's patch to fix query-cancel in hot
Erik Rijkers reviewed Hitoshi Harada's windowing function patch and
found some regression test irregularities.
Robert Haas reviewed Pavel Stehule's new patch for psql which enables
quoting and said it was excessively simplified.
Kevin Grittner reviewed Leonardo F's patch to add substring and
replace() to get and set bit values. It no longer applies.
Robert Haas reviewed ITAGAKI Takahiro's patch to add partitioning
syntax and suggested some improvements to the documentation of LIST
and RANGE partitions.
Magnus Hagander reviewed Greg Smith's revision of the patch to allow
clearing global statistics.
Jan Urbanski reviewed Arie Bikker's patch to improve xpath handling.
Gregory Stark reviewed the Bloom index patch and noted some
infelicities with rand() and srand(), i.e. they shouldn't be there.
== Applied Patches ==
Andrew Dunstan committed:
- In pgsql/src/tools/msvc/Mkvcbuild.pm, remove use of temp file for
perlchunks.h, as in recent change to plperl GNUmakefile
Tom Lane committed:
- In pgsql/src/backend/executor/execQual.c, improve ExecEvalVar's
handling of whole-row variables in cases where the rowtype contains
dropped columns. Sometimes the input tuple will be formed from a
select targetlist in which dropped columns are filled with a NULL of
an arbitrary type (the planner typically uses INT4, since it can't
tell what type the dropped column really was). So we need to relax
the rowtype compatibility check to not insist on physical
compatibility if the actual column value is NULL. In principle we
might need to do this for functions returning composite types, too
(see tupledesc_match()). In practice there doesn't seem to be a bug
there, probably because the function will be using the same cached
rowtype descriptor as the caller. Fixing that code path would
require significant rearrangement, so I left it alone for now. Per
complaint from Filip Rembialkowski.
- Add some simple support and documentation for using process-specific
oom_adj settings to prevent the postmaster from being OOM-killed on
Linux systems. Alex Hunsaker and Tom Lane.
- In pgsql/src/backend/utils/adt/acl.c, fix aclexplode to not explode
on a zero-entry ACL array. (An Assert is no substitute for thinking
clearly :-() Minor style kibitzing too. Per report from Robert
- In pgsql/src/backend/utils/cache/relcache.c, fix relcache reload
mechanism to be more robust in the face of errors occurring during a
reload, such as query-cancel. Instead of zeroing out an existing
relcache entry and rebuilding it in place, build a new relcache
entry, then swap its contents with the old one, then free the new
entry. This avoids problems with code believing that a previously
obtained pointer to a cache entry must still reference a valid
entry, as seen in recent failures on buildfarm member jaguar.
(jaguar is using CLOBBER_CACHE_ALWAYS which raises the probability
of failure substantially, but the problem could occur in the field
without that.) The previous design was okay when it was made, but
subtransactions and the ResourceOwner mechanism make it unsafe now.
Also, make more use of the already existing rd_isvalid flag, so that
we remember that the entry requires rebuilding even if the first
attempt fails. Back-patch as far as 8.2. Prior versions have
enough issues around relcache reload anyway (due to inadequate
locking) that fixing this one doesn't seem worthwhile.
- In pgsql/src/backend/parser/parse_param.c, make fixed_paramref_hook
behave properly when there are 'unused' slots in the parameter
array. Noted while experimenting with an example from Pavel
Stehule. This wouldn't come up in normal use, but it ought to honor
the specification that a parameter array can have unused slots.
- In pgsql/src/backend/utils/cache/plancache.c, fix bug #5269:
ResetPlanCache mustn't invalidate cached utility statements,
especially not ROLLBACK. ROLLBACK might need to be executed in an
already aborted transaction, when there is no safe way to revalidate
the plan. But in general there's no point in marking utility
statements invalid, since they have no plans in the normal sense of
the word; so we might as well work a bit harder here to avoid future
revalidation cycles. Back-patch to 8.4, where the bug was
- In pgsql/src/backend/utils/cache/relcache.c, when loading critical
system indexes into the relcache, ensure we lock the underlying
catalog not only the index itself. Otherwise, if the cache load
process touches the catalog (which will happen for many though not
all of these indexes), we are locking index before parent table,
which can result in a deadlock against processes that are trying to
lock them in the normal order. Per today's failure on buildfarm
member gothic_moth; it's surprising the problem hadn't been
identified before. Back-patch to 8.2. Earlier releases didn't have
the issue because they didn't try to lock these indexes during load
(instead assuming that they couldn't change schema at all during
- In pgsql/src/port/exec.c, simplify validate_exec() by using
access(2) to check file permissions, rather than trying to implement
the equivalent logic by hand. The motivation for the original
coding appears to have been to check with the effective uid's
permissions not the real uid's; but there is no longer any
difference, because we don't run the postmaster setuid (indeed,
main.c enforces that they're the same). Using access() means we
will get it right in situations the original coding failed to
handle, such as ACL-based permissions. Besides it's a lot shorter,
cleaner, and more thread-safe. Per bug #5275 from James Bellinger.
- In pgsql/src/backend/replication/walreceiver/Makefile, fix bogus
subdir setting ... wonder just what that affects ...
- In pgsql/src/backend/replication/walreceiver/Makefile, actually,
I'll bet the mingw problem is lack of $(BE_DLLLIBS) ...
- In pgsql/src/backend/replication/walreceiver/Makefile, no, scratch
that, it was getting added twice.
- Second try: walreceiver should not be built with -DBUILDING_DLL
- Do parse analysis of an EXPLAIN's contained statement during the
normal parse analysis phase, rather than at execution time. This
makes parameter handling work the same as it does in ordinary
plannable queries, and in particular fixes the incompatibility that
Pavel pointed out with plpgsql's new handling of variable
references. plancache.c gets a little bit grottier, but the
alternatives seem worse.
- PGDLLIMPORT-ize the remaining variables needed by walreceiver.
- In pgsql/src/include/libpq/pqsignal.h, huh, apparently on cygwin we
HAVE_SIGPROCMASK, so both variants of the BlockSig/UnBlockSig
declaration have to be PGDLLIMPORT'ified. Per buildfarm results.
- In pgsql/src/backend/storage/ipc/procarray.c, fix bogus
initialization of KnownAssignedXids shared memory state --- didn't
work in EXEC_BACKEND case.
- In pgsql/src/backend/parser/scan.l, fix unportable use of isxdigit()
with char (rather than unsigned char) argument, per warnings from
buildfarm member pika. Also clean up code formatting a trifle.
- Re-order configure tests to reflect the fact that the code generated
for posix_fadvise and other file-related functions can depend on
_LARGEFILE_SOURCE and/or _FILE_OFFSET_BITS. Per report from Robert
Treat. Back-patch to 8.4. This has been wrong all along, but we
weren't really using posix_fadvise in anger before, and
AC_FUNC_FSEEKO seems to mask the issue well enough for that
- In pgsql/src/backend/tcop/postgres.c, remove unnecessary,
inconsistent flag resets in ProcessInterrupts.
- Improve the handling of SET CONSTRAINTS commands by having them
search pg_constraint before searching pg_trigger. This allows saner
handling of corner cases; in particular we now say "constraint is
not deferrable" rather than "constraint does not exist" when the
command is applied to a constraint that's inherently non-deferrable.
Per a gripe several months ago from hubert depesz lubaczewski. To
make this work without breaking user-defined constraint triggers, we
have to add entries for them to pg_constraint. However, in return
we can remove the pgconstrname column from pg_constraint, which
represents a fairly sizable space savings. I also replaced the
tgisconstraint column with tgisinternal; the old meaning of
tgisconstraint can now be had by testing for nonzero tgconstraint,
while there is no other way to get the old meaning of nonzero
tgconstraint, namely that the trigger was internally generated
rather than being user-created. In passing, fix an old misstatement
in the docs and comments, namely that pg_trigger.tgdeferrable is
exactly redundant with pg_constraint.condeferrable. Actually, we
mark RI action triggers as nondeferrable even when they belong to a
nominally deferrable FK constraint. The SET CONSTRAINTS code now
relies on that instead of hard-coding a list of exception OIDs.
- In pgsql/doc/src/sgml/ref/set_constraints.sgml, update SET
CONSTRAINTS reference page --- it failed to mention EXCLUDE
constraints and was lacking a couple of other interesting details.
- In pgsql/src/backend/utils/mmgr/portalmem.c, fix portalmem.c to
avoid keeping a dangling pointer to a cached plan list after it's
released its reference count for the cached plan. There are code
paths that might try to examine the plan list before noticing that
the portal is already in aborted state. Report and diagnosis by
Tatsuo Ishii, though this isn't exactly his proposed patch.
Bruce Momjian committed:
- In pgsql/doc/src/sgml/backup.sgml, remove tabs in SGML file.
- Place tablespace directories in their own subdirectory so
pg_migrator can upgrade clusters without renaming the tablespace
directories. New directory structure format is, e.g.:
- In src/backend/replication/walreceiver/walreceiver.c, add #include
<sys/time.h> for struct timeval definition on BSD/OS.
Michael Meskes committed:
- In pgsql/src/interfaces/ecpg/ecpglib/typename.c, applied Zoltan
Boszormenyi's patch to make char the default sqlda type. Given that
undefined types are handled as character strings anyway the type
translation function can simply return the correcponding ECPGt_char
- Applied patch by Zoltan Boszormenyi to add DESCRIBE [OUTPUT]
statement to ecpg.
- In pgsql/src/interfaces/ecpg/ecpglib/descriptor.c, added correct
error handling in DESCRIBE statement processing by Zoltan
- Removed ecpg Changelog file that was only there for historical
reasons and isn't actively used anymore.
- Fix SQL3 type return value. For non-SQL3 types ecpg used to return
-Oid. This will break if there are enough Oids to fill the
namespace. Therefore we play it safe and return 0 if there is no
Oid->SQL3 tyoe mapping available.
Magnus Hagander committed:
- In pgsql/doc/src/sgml/install-win32.sgml, update MSVC build
instructions. Updated to reflect building with Visual Studio 2008,
with just the Platform SDK, and for 64-bit Windows.
- In pgsql/src/tools/msvc/Mkvcbuild.pm, build the walreceiver library
on MSVC as well.
- In pgsql/doc/src/sgml/installation.sgml, fix spelling error, noticed
by Thomas Shinnick.
- In pgsql/contrib/xml2/xpath.c, silence compiler warning, noted by
- In pgsql/src/tools/msvc/Mkvcbuild.pm, add include directory for
dblink to find fmgroids.h on VS2008 builds.
Simon Riggs committed:
- First part of refactoring of code for ResolveRecoveryConflict.
Purposes of this are to centralise the conflict code to allow
further change, as well as to allow passing through the full reason
for the conflict through to the conflicting backends. Backend state
alters how we can handle different types of conflict so this is now
required. As originally suggested by Heikki, no longer optional.
- Teach standby conflict resolution to use SIGUSR1. Conflict reason
is passed through directly to the backend, so we can take decisions
about the effect of the conflict based upon the local state. No
specific changes, as yet, though this prepares for later work.
CancelVirtualTransaction() sends signals while holding
ProcArrayLock. Introduce errdetail_abort() to give message detail
explaining that the abort was caused by conflict processing. Remove
CONFLICT_MODE states in favour of using PROCSIG_RECOVERY_CONFLICT
states directly, for clarity.
- In pgsql/src/backend/storage/ipc/standby.c, message mentions msec
when it should be seconds, so use s instead of ms. Noticed by
- In pgsql/src/backend/commands/dbcommands.c, lock database while
running drop database in Hot Standby to protect against concurrent
reconnection. Failure during testing showed issue was possible, even
though earlier analysis seemed to indicate it would not be required.
Use LockSharedObjectForSession() before
ResolveRecoveryConflictWithDatabase() and hold lock until end of
processing for that WAL record. Simple approach to avoid introducing
further bugs at this stage of development on an improbable issue.
Teodor Sigaev committed:
- Add point_ops opclass for GiST.
Heikki Linnakangas committed:
- Introduce Streaming Replication. This includes two new kinds of
postmaster processes, walsenders and walreceiver. Walreceiver is
responsible for connecting to the primary server and streaming WAL
to disk, while walsender runs in the primary server and streams WAL
from disk to the client. Documentation still needs work, but the
basics are there. We will probably pull the replication section to
a new chapter later on, as well as the sections describing
file-based replication. But let's do that as a separate patch, so
that it's easier to see what has been added/changed. This patch
also adds a new section to the chapter about FE/BE protocol,
documenting the protocol used by walsender/walreceivxer. Bump
catalog version because of two new functions,
pg_last_xlog_receive_location() and pg_last_xlog_replay_location(),
for monitoring the progress of replication. Fujii Masao, with
additional hacking by Heikki Linnakangas.
- In pgsql/src/backend/replication/walsender.c, remove unused (in
non-assertion-enabled build) variable.
- In pgsql/src/Makefile, move build of
src/backend/replication/walreceiver/ later in the build process,
after src/interfaces, because it depends on libpq. Also add missing
lines for clean, etc. targets. Report from Zoltan Boszormenyi.
Peter Eisentraut committed:
- Improved printing of Python exceptions in PL/Python. Mimic the
Python interpreter's own logic for printing exceptions instead of
just using the straight str() call, so that you get plpy.SPIError
instead of <class 'plpy.SPIError'> and for built-in exceptions
merely, UnicodeEncodeError. Besides looking better this cuts down
on the endless version differences in the regression test expected
== Abgelehnte Patches (bis jetzt) ==
No one was disappointed this week :-)
== Eingesandte Patches ==
Pavel Stehule sent in two more revisions of the patch to introduce
quoting behavior to psql variables.
Zoltan Boszormenyi sent in four revisions of the lock_timeout GUC
patch. Jaime Casanova one after Zoltan's first.
ITAGAKI Takahiro sent in a patch to fix a memory leak in dblink when
a tuple-returning query gets cancelled.
Andreas Freund sent in a WIP patch to address an issue where hot
standby doesn't play well with cancelling queries.
KaiGai Kohei sent in a patch clarifying comments in
Marko (johto) Tiikkaja sent in another revision of the writeable CTE
Teodor Sigaev sent in several patches as WIP to implement
Kevin Grittner sent in a .gitignore file.
ITAGAKI Takahiro sent in a patch to correct an error in execMain.c
when there's a NOT NULL violation.
Peter Eisentraut sent in a patch to change the order in which pg_dump
Pavel Stehule sent in a patch to make psql remove redundant
parentheses in trigger definitions.
Hans-Juergen Schoenig sent in a patch to add SQL tracing and tracking
Pavel Stehule sent in a patch against PL/pgsql which adds an optional
USING clause to OPEN FOR EXECUTE.
Hitoshi Harada sent in two more revisions of the patch to extend ROWS
and RANGE in windowing context, one per Pavel Stehule's review.
Teodor Sigaev sent in another WIP patch to add Bloom indexes as a
Simon Riggs sent in three revisions of a patch to fix the query-cancel
issue in hot standby.
Kevin Grittner sent in another WIP patch for serializable isolation.
Tim Bunce sent in a patch for PL/Perl which adds utility functions,
names stored procedures as $name__$oid, cleans up whitespace in
warnings, does some minor optimizations, and properly uses the
recently updated ppport.h.
KaiGai Kohei sent in another revision of the patch to fix ALTER
TABLE...RENAME TO behavior on multiply inherited columns.
Tim Bunce sent in a patch against PL/Perl which enables "require,"
(works for preloaded modules), "use strict" (and there was much
rejoicing), some 5.10 features, named stored procedure subroutines,
simplified and generalized subroutine creation code, some other
optimizations, and disallows the buggy Safe.pm 2.20.
Markus Wanner (ne Schiltknecht) sent in a tool for testing in
concurrent sessions called dtester.
ITAGAKI Takahiro sent in another revision of the PARTITION syntax
Simon Riggs sent in a patch to fix a bug with GetConflictingVirtualXIDs.
Greg Smith sent in a patch to clear global statistics.
Bernd Helmle sent in a patch to enable seeing the total table size
Tim Bunce sent in a patch which adds on_perl_init and proper
destruction to PL/Perl.
Tim Bunce sent in a patch for PL/Perl which adds plperl.on_trusted_init
and plperl.on_untrusted_init GUCs, improves state management in
select_perl_context(), and simplifies the utf8fix code.
Tim Bunce sent in a patch for PL/Perl which moves the internal
functions from the main:: namespace to PostgreSQL::InServer and
PostgreSQL::InServer::safe and restructures the Safe compartment setup
Peter Eisentraut sent in a patch to add a per-user pg_service.conf.
Alex Hunsaker sent in a review and patch atop Robert Haas's attoptions
Heikki Linnakangas sent in another version of the patch to add a new
XLOG record indicating WAL-skipping.
Guillaume Lelarge sent in another revision of the application name
patch for libpq.
Heikki Linnakangas sent in a patch which pulls walreceiver into the
backend executable and adds some interface functions to it.
Hitoshi Harada sent in a patch to fix the windowing functions patch
per feedback from Erik Rijkers.
Peter Eisentraut sent in a patch to remove a gcc dependency from
the definition of inline functions.
Peter Eisentraut sent in a patch to rearrange the parallel regression
tests so they output the names before they all start instead of after
they all finish.
Tatsuo Ishii sent in a patch which sets portal->stmts to NULL in
src/backend/utils/mmgr/portalmem.c just after
PortalReleaseCachedPlan(portal) in order to fix an issue he found
Fujii Masao sent in a patch which adjust streaming replication for
some later changes.