E.15. Выпуск 11.8
Дата выпуска: 2020-05-14
В этот выпуск вошли различные исправления, внесённые после версии 11.7. За информацией о нововведениях версии 11 обратитесь к Разделу E.23.
E.15.1. Миграция на версию 11.8
Если используется версия 11.X, выгрузка/восстановление базы не требуется.
Если вы обновляете сервер с более ранней версии, чем 11.6, см. также Раздел E.17.
E.15.2. Изменения
Распространение действия
ALTER TABLE ... SET STORAGE
на индексы (Питер Эйзентраут)Для столбцов в индексах (кроме индексов по выражениям) при создании индекса всегда копировалось свойство
attstorage
из столбца в таблице. Теперь это свойство для согласованности будет меняться для них при выполнении командыALTER TABLE ... SET STORAGE
.Сохранение свойства
indisclustered
у индексов, перезаписываемых командойALTER TABLE
(Амит Ланготе, Джастин Призби)Ранее команда
ALTER TABLE
теряла информацию о том, для какого индекса выполнялась командаCLUSTER
.Сохранение свойства идентификации реплики у индексов, перезаписываемых командой
ALTER TABLE
(Цюань Цзунлян, Питер Эйзентраут)Блокирование объектов на более ранней стадии выполнения
DROP OWNED BY
(Альваро Эррера)Это позволяет исключить ошибки в условиях гонки, когда какие-либо из удаляемых объектов параллельно удаляются в другом сеансе.
Исправление обработки ошибок при выполнении
CREATE ROLE ... IN ROLE
(Эндрю Гирт)В некоторых случаях при ошибке вместо надлежащего сообщения выдавалось «unexpected node type» (неожиданный тип узла) или что-то подобное.
Удаление из таблицы, отсоединяемой от секционированной родительской таблицы, всех триггеров, ранее скопированных в неё из последней (Джастин Призби)
Проверка совпадения семантики уникальных индексов в секционированных таблицах с семантикой равенства для ключа секционирования (Гуаньчэн Ло)
Проблема была возможна только при необычном определении равенства в классах операторов, используемых индексами, но в принципе несоответствия не должны допускаться, и это следует проверить.
Предоставление всем членам роли
pg_read_all_stats
доступа ко всем статистическим представлениям, согласно ожиданиям (Магнус Хагандер)Нижележащие функции представлений
pg_stat_progress_*
ранее не считали эту роль имеющей соответствующие полномочия.Устранение падения производительности при обращении к представлению
information_schema
.triggers
(Том Лейн)В результате исправления представление было переопределено так, чтобы внешнее предложение
WHERE
, ограничивающее имя таблицы, могло передаваться ниже, благодаря чему все вычисления теперь могут производиться только для триггеров, относящихся к избранных таблицам, а не для вообще всех триггеров в базе. В базе, где создано множество триггеров, это изменение позволяет значительно ускорить запросы к этому представлению. До 11 версии этого падения производительности не наблюдалось, поэтому можно считать это нововведённым дефектом. Если для кого-то это является серьёзной проблемой, её можно устранить, заменив определение представления (или, возможно, просто удалив и пересоздав всю схемуinformation_schema
).Исправление в полнотекстовом поиске обработки отрицания для результата поиска фразы (Том Лейн)
Запросы вида
!(foo<->bar)
не могли найти нужные строки, когда применялся поиск по индексу GiST или GIN.Исправление полнотекстового поиска в ситуациях, когда в поисковой фразе оказывается элемент, задающий и искомый префикс, и вес (Том Лейн)
Улучшение выбора выдержек из документа в функции
ts_headline()
при обработке фразовых запросов (Том Лейн)Устранение ошибок в обработке
gin_fuzzy_search_limit
(Аде Хэйуорд, Том Лейн)При небольшом значении
gin_fuzzy_search_limit
выполнение запросов могло неожиданно замедляться из-за непреднамеренного многократного сканирования одной и той же страницы индекса. В другом месте кода желаемая фильтрация не применялась вовсе, в результате чего могло возвращаться слишком много значений.Добавление в набор форматов, допустимых для типа
circle
, формата «(
», который должен приниматься согласно документации (Дэвид Чжан)x
,y
),r
Доработка функций
get_bit()
иset_bit()
для поддержки строкbytea
длиннее 256 МБ (Мувад Ли)Так как аргумент, задающий номер бита, имеет тип
int4
, с помощью этих функций нельзя обращаться к битам за пределами первых 256 мегабайт значенияbytea
. В 13 версии тип аргумента будет расширен доint8
, а тем временем в текущей версии обеспечена поддержка этими функциями больших значенийbytea
в обозначенном пределе.Игнорирование ошибок «файл не найден» в
pg_ls_waldir()
и родственных функциях (Том Лейн)Это устраняет сбой в условиях гонки, когда файл удаляется между моментом, когда мы получили запись о нём в каталоге, и моментом, когда мы пытаемся получить дополнительную информацию о нём, вызывая
stat()
.Устранение возможной утечки открытого дескриптора каталога в
pg_ls_dir()
,pg_timezone_names()
,pg_tablespace_databases()
и родственных функциях (Джастин Призби)Исправление разрешения типов в полиморфных функциях, чтобы фактический тип результата
anyarray
выводился из входного типа, если на вход поступает толькоanyrange
(Том Лейн)Ликвидация потери хеш-таблиц в подплане с хешированием при многократном выполнении подплана (Андреас Карлссон, Том Лейн)
При достаточно большом количестве повторений такого подплана объём потерянной памяти мог оказаться весьма заметным.
Устранение возможности сбоя при прерывании команды
REINDEX
сигналом завершения сеанса (Том Лейн)Устранение маловероятного сбоя в случае нарушения условий ограничений в секционированных таблицах (Андрес Фройнд)
Предотвращение отображения мусорных данных при выводе статистики таблицы соединения по хешу в
EXPLAIN
(Константин Книжник, Том Лейн, Томас Манро)Исправление расчёта длительности этапов в процедуре усечения кучи при выполнении
VACUUM VERBOSE
(Тацухито Касахара)Устранение потенциальной недооценки числа удалённых страниц индексов-B-деревьев в выводе
VACUUM VERBOSE
(Питер Гейган)Исправление обработки старейшей удалённой страницы в индексе-B-дереве (Питер Гейган)
В результате ошибки могли приниматься неправильные решения о пропуске очистки индекса при выполнении
VACUUM
, хотя по всей видимости для пользователей этот дефект никак не проявлялся.Обеспечение передачи состояний ожидания TimelineHistoryRead и TimelineHistoryWrite во всех местах в коде, где читаются и записываются файлы истории линий времени (Масахиро Икеда)
Предотвращение повторного добавления «waiting» (ожидание) в заголовок процесса, выводимый PS (Масахико Савада)
Предотвращение сбоя при попытке обратиться в процедуре автоочистки к только что удалённой временной схеме (Том Лейн)
Сбой был возможен только в случае удаления временной схемы суперпользователем, что практикуется нечасто, но всё же должно обрабатываться корректно.
Предотвращение преждевременного перерабатывания сегментов WAL во время восстановления после сбоя (Жеан-Гийом де Рорте)
Сегменты WAL, которые становились готовыми к архивации в ходе процедуры восстановления, могли перерабатываться, не попадая в архив.
Отказ от сканирования неактуальных линий времени в ходе восстановления архива (Кётаро Хоригути)
Теперь не будут производиться многократные попытки считать несуществующие файлы WAL из архивного хранилища, что важно при низкоскоростном подключении к архиву.
Удаление ненужной проверки, сигнализирующей об ошибке «subtransaction logged without previous top-level txn record» (записи подтранзакции в журнале не предшествует запись транзакции верхнего уровня) (Арсений Шер, Амит Капила)
Ситуация, которая ранее считалась недопустимой, могла сложиться на вполне законных основаниях, поэтому данную проверку следует удалить.
Обеспечение снятия блокировки
io_in_progress_lock
для слота репликации при обработке нештатных ситуаций (Паван Деоласи)Ранее блокировка снималась не всегда, вследствие чего процесс walsender мог зависнуть в ожидании.
Устранение условий гонки при управлении синхронными ведомыми серверами (Том Лейн)
В процессе применения изменений параметра
synchronous_standby_names
существовало окно, в котором могли быть приняты неверные решения об освобождении транзакций, ожидающих синхронной фиксации. Подобные неверные решения могли приниматься и тогда, когда после завершения процесса walsender он сразу же заменялся другим.Недопущение изменения
nextXid
в обратном направлении на ведомом сервере (Ека Паламадай)В результате условия гонки сервер горячего резерва мог передавать ведущему серверу некорректные ответные сообщения, вследствие чего на ведущем операция
VACUUM
могла выполняться раньше времени.Добавление значений SQLSTATE в формируемые отчёты об ошибках в нескольких местах (Масахико Савада)
Реализация в PL/pgSQL надёжного метода пресечения попытки выполнить функцию событийного триггера как обычную функцию (Том Лейн)
Устранение утечки памяти в libpq при использовании режима
sslmode=verify-full
(Роман Пешкуров)При проверке сертификата на стадии установления соединения была возможна утечка памяти. Это могло стать серьёзной проблемой, если клиентский процесс в своём жизненном цикле устанавливал много подключений к базе данных.
Обработка в ecpg аргумента «
-
» как означающего «читать с stdin» на всех платформах (Том Лейн)Добавление дополнения табуляцией имени файла для команды psql
\gx
(Вик Фиринг)Добавление в pg_dump поддержки конструкции
ALTER ... DEPENDS ON EXTENSION
(Альваро Эррера)Ранее программа pg_dump игнорировала зависимости, добавленные таким образом, вследствие чего они терялись после выгрузки/восстановления или выполнения pg_upgrade.
Исправление в pg_dump выгрузки комментариев к объектам политики RLS (Том Лейн)
Перенос в выгрузке pg_dump восстановления событийных триггеров на финальный этап (Фабрицио де Ройес Мелло, Хамид Ахтар, Том Лейн)
Это снижает риск нежелательного влияния событийных триггеров на восстановление других объектов.
Исключение подкаталогов табличных пространств, относящихся к другим версиям PostgreSQL, из проверки pg_verify_checksums (Михаэль Банк, Бернд Хелмле)
Такие подкаталоги на самом деле не имеют отношения к текущему кластеру баз данных, поэтому их проверять не следует.
Исключение временных копий
pg_internal.init
из проверки утилиты pg_verify_checksums и связанных программ (Микаэль Пакье)Исправление обработки кавычек в значениях параметров
--encoding
,--lc-ctype
и--lc-collate
утилиты createdb (Микаэль Пакье)Устранение краха при попытке вызвать функцию
lo_manage()
изcontrib/lo
как обычную функцию, а не в качестве триггера (Том Лейн)Защита от переполнения полей длины в типах
ltree
иlquery
модуляcontrib/ltree
(Никита Глухов)Реализация обходного решения проблемы в функции
bt_metap()
модуляcontrib/pageinspect
, возникавшей со значением oldest_xact, превышающим 2^31-1 (Питер Гейган)Некоторые идентификаторы транзакций теперь будут отображаться как отрицательные числа, что не вполне корректно, но лучше, чем ошибка. В 13 версии соответствующий выходной аргумент будет расширен до
int8
, и тогда проблема будет решена полностью.Устранение утечки ссылки на кеш в
contrib/sepgsql
(Майкл Ло)Исправление обработки имён локалей в стиле Unix на платформе Windows (Хуан Хосе Сантамария Флеча)
Использование pkg-config для определения расположения libxml2 в процедуре configure (Хью Макмастер, Том Лейн, Питер Эйзентраут)
Если утилита pkg-config отсутствует или не имеет информации о libxml2, мы будем использовать xml2-config, как и прежде.
Это изменение может нарушить процедуры сборки PostgreSQL, в которых для использования нестандартной версии libxml2 путь к нужной версии xml2-config добавляется в
PATH
. Теперь вместо этого нужно указать путь к нужному xml2-config в переменной окруженияXML2_CONFIG
. Этот метод будет работать и с новыми, и со старыми версиями PostgreSQL.Исправление в сборках MSVC манипуляции с путём к Python с учётом того, что он может содержать пробелы (Виктор Вагнер)
Исправление в сборках MSVC определения версии Visual Studio во избежание зависимости от языковых настроек (Эндрю Дунстан)
Использование в сборках MSVC ключа
-Wno-deprecated
с bison версии новее 3.0, как уже делается в сборках для отличных от Windows ОС (Эндрю Дунстан)Обновление данных часовых поясов до версии tzdata 2020a, включающее изменение правил перехода на летнее время в Марокко и канадском Юконе, а также корректировку исторических данных для Шанхая.
Часовой пояс America/Godthab был переименован в America/Nuuk в соответствии с принятым сейчас названием; старое обозначение сохранено для совместимости в виде ссылки.
Также был актуализирован список известных initdb часовых поясов в Windows, так что теперь параметры системного часового пояса на этой платформе будут восприняты корректно с большей вероятностью.
E.15. Release 11.8
Release date: 2020-05-14
This release contains a variety of fixes from 11.7. For information about new features in major release 11, see Section E.23.
E.15.1. Migration to Version 11.8
A dump/restore is not required for those running 11.X.
However, if you are upgrading from a version earlier than 11.6, see Section E.17.
E.15.2. Changes
Propagate
ALTER TABLE ... SET STORAGE
to indexes (Peter Eisentraut)Non-expression index columns have always copied the
attstorage
property of their table column at creation. Update them whenALTER TABLE ... SET STORAGE
is done, to maintain consistency.Preserve the
indisclustered
setting of indexes rewritten byALTER TABLE
(Amit Langote, Justin Pryzby)Previously,
ALTER TABLE
lost track of which index had been used forCLUSTER
.Preserve the replica identity properties of indexes rewritten by
ALTER TABLE
(Quan Zongliang, Peter Eisentraut)Lock objects sooner during
DROP OWNED BY
(Álvaro Herrera)This avoids failures in race-condition cases where another session is deleting some of the same objects.
Fix error-case processing for
CREATE ROLE ... IN ROLE
(Andrew Gierth)Some error cases would be reported as “unexpected node type” or the like, instead of the intended message.
Ensure that when a partition is detached, any triggers cloned from its formerly-parent table are removed (Justin Pryzby)
Ensure that unique indexes over partitioned tables match the equality semantics of the partitioning key (Guancheng Luo)
This would only be an issue with index opclasses that have unusual notions of equality, but it's wrong in theory, so check.
Ensure that members of the
pg_read_all_stats
role can read all statistics views, as expected (Magnus Hagander)The functions underlying the
pg_stat_progress_*
views had not gotten this memo.Repair performance regression in
information_schema
.triggers
view (Tom Lane)This patch redefines that view so that an outer
WHERE
clause constraining the table name can be pushed down into the view, allowing its calculations to be done only for triggers belonging to the table of interest rather than all triggers in the database. In a database with many triggers this would make a significant speed difference for queries of that form. Since things worked that way before v11, this is a potential performance regression. Users who find this to be a problem can fix it by replacing the view definition (or, perhaps, just deleting and reinstalling the wholeinformation_schema
schema).Fix full text search to handle NOT above a phrase search correctly (Tom Lane)
Queries such as
!(foo<->bar)
failed to find matching rows when implemented as a GiST or GIN index search.Fix full text search for cases where a phrase search includes an item with both prefix matching and a weight restriction (Tom Lane)
Fix
ts_headline()
to make better headline selections when working with phrase queries (Tom Lane)Fix bugs in
gin_fuzzy_search_limit
processing (Adé Heyward, Tom Lane)A small value of
gin_fuzzy_search_limit
could result in unexpected slowness due to unintentionally rescanning the same index page many times. Another code path failed to apply the intended filtering at all, possibly returning too many values.Allow input of type
circle
to accept the format “(
” as the documentation says it does (David Zhang)x
,y
),r
Make the
get_bit()
andset_bit()
functions cope withbytea
strings longer than 256MB (Movead Li)Since the bit number argument is only
int4
, it's impossible to use these functions to access bits beyond the first 256MB of a longbytea
. We'll widen the argument toint8
in v13, but in the meantime, allow these functions to work on the initial substring of a longbytea
.Ignore file-not-found errors in
pg_ls_waldir()
and allied functions (Tom Lane)This prevents a race condition failure if a file is removed between when we see its directory entry and when we attempt to
stat()
it.Avoid possibly leaking an open-file descriptor for a directory in
pg_ls_dir()
,pg_timezone_names()
,pg_tablespace_databases()
, and allied functions (Justin Pryzby)Fix polymorphic-function type resolution to correctly infer the actual type of an
anyarray
output when given only ananyrange
input (Tom Lane)Avoid leakage of a hashed subplan's hash tables across multiple executions (Andreas Karlsson, Tom Lane)
This mistake could result in severe memory bloat if a query re-executed a hashed subplan enough times.
Avoid unlikely crash when
REINDEX
is terminated by a session-shutdown signal (Tom Lane)Fix low-probability crash after constraint violation errors in partitioned tables (Andres Freund)
Prevent printout of possibly-incorrect hash join table statistics in
EXPLAIN
(Konstantin Knizhnik, Tom Lane, Thomas Munro)Fix reporting of elapsed time for heap truncation steps in
VACUUM VERBOSE
(Tatsuhito Kasahara)Fix possible undercounting of deleted B-tree index pages in
VACUUM VERBOSE
output (Peter Geoghegan)Fix wrong bookkeeping for oldest deleted page in a B-tree index (Peter Geoghegan)
This could cause subtly wrong decisions about when
VACUUM
can skip an index cleanup scan; although it appears there may be no significant user-visible effects from that.Ensure that TimelineHistoryRead and TimelineHistoryWrite wait states are reported in all code paths that read or write timeline history files (Masahiro Ikeda)
Avoid possibly showing “waiting” twice in a process's PS status (Masahiko Sawada)
Avoid failure if autovacuum tries to access a just-dropped temporary schema (Tom Lane)
This hazard only arises if a superuser manually drops a temporary schema; which isn't normal practice, but should work.
Avoid premature recycling of WAL segments during crash recovery (Jehan-Guillaume de Rorthais)
WAL segments that become ready to be archived during crash recovery were potentially recycled without being archived.
Avoid scanning irrelevant timelines during archive recovery (Kyotaro Horiguchi)
This can eliminate many attempts to fetch non-existent WAL files from archive storage, which is helpful if archive access is slow.
Remove bogus “subtransaction logged without previous top-level txn record” error check in logical decoding (Arseny Sher, Amit Kapila)
This condition is legitimately reachable in various scenarios, so remove the check.
Ensure that a replication slot's
io_in_progress_lock
is released in failure code paths (Pavan Deolasee)This could result in a walsender later becoming stuck waiting for the lock.
Fix race conditions in synchronous standby management (Tom Lane)
During a change in the
synchronous_standby_names
setting, there was a window in which wrong decisions could be made about whether it is OK to release transactions that are waiting for synchronous commit. Another hazard for similarly wrong decisions existed if a walsender process exited and was immediately replaced by another.Ensure
nextXid
can't go backwards on a standby server (Eka Palamadai)This race condition could allow incorrect hot standby feedback messages to be sent back to the primary server, potentially allowing
VACUUM
to run too soon on the primary.Add missing SQLSTATE values to a few error reports (Sawada Masahiko)
Fix PL/pgSQL to reliably refuse to execute an event trigger function as a plain function (Tom Lane)
Fix memory leak in libpq when using
sslmode=verify-full
(Roman Peshkurov)Certificate verification during connection startup could leak some memory. This would become an issue if a client process opened many database connections during its lifetime.
Fix ecpg to treat an argument of just “
-
” as meaning “read from stdin” on all platforms (Tom Lane)Allow tab-completion of the filename argument to psql's
\gx
command (Vik Fearing)Add pg_dump support for
ALTER ... DEPENDS ON EXTENSION
(Álvaro Herrera)pg_dump previously ignored dependencies added this way, causing them to be forgotten during dump/restore or pg_upgrade.
Fix pg_dump to dump comments on RLS policy objects (Tom Lane)
In pg_dump, postpone restore of event triggers till the end (Fabrízio de Royes Mello, Hamid Akhtar, Tom Lane)
This minimizes the risk that an event trigger could interfere with the restoration of other objects.
Make pg_verify_checksums skip tablespace subdirectories that belong to a different PostgreSQL major version (Michael Banck, Bernd Helmle)
Such subdirectories don't really belong to our database cluster, and so must not be processed.
Ignore temporary copies of
pg_internal.init
in pg_verify_checksums and related programs (Michael Paquier)Fix quoting of
--encoding
,--lc-ctype
and--lc-collate
values in createdb utility (Michael Paquier)contrib/lo
'slo_manage()
function crashed if called directly rather than as a trigger (Tom Lane)In
contrib/ltree
, protect against overflow ofltree
andlquery
length fields (Nikita Glukhov)Work around failure in
contrib/pageinspect
'sbt_metap()
function when an oldest_xact value exceeds 2^31-1 (Peter Geoghegan)Such XIDs will now be reported as negative integers, which isn't great but it beats throwing an error. v13 will widen the output argument to
int8
to provide saner reporting.Fix cache reference leak in
contrib/sepgsql
(Michael Luo)Avoid failures when dealing with Unix-style locale names on Windows (Juan José Santamaría Flecha)
Use pkg-config, if available, to locate libxml2 during configure (Hugh McMaster, Tom Lane, Peter Eisentraut)
If pkg-config is not present or lacks knowledge of libxml2, we still query xml2-config as before.
This change could break build processes that try to make PostgreSQL use a non-default version of libxml2 by putting that version's xml2-config into the
PATH
. Instead, setXML2_CONFIG
to point to the non-default xml2-config. That method will work with either older or newer PostgreSQL releases.In MSVC builds, cope with spaces in the path name for Python (Victor Wagner)
In MSVC builds, fix detection of Visual Studio version to work with more language settings (Andrew Dunstan)
In MSVC builds, use
-Wno-deprecated
with bison versions newer than 3.0, as non-Windows builds already do (Andrew Dunstan)Update time zone data files to tzdata release 2020a for DST law changes in Morocco and the Canadian Yukon, plus historical corrections for Shanghai.
The America/Godthab zone has been renamed to America/Nuuk to reflect current English usage; however, the old name remains available as a compatibility link.
Also, update initdb's list of known Windows time zone names to include recent additions, improving the odds that it will correctly translate the system time zone setting on that platform.