E.21. Postgres Pro Enterprise 11.8.1

Дата выпуска: 2020-05-28

E.21.1. Обзор

Этот выпуск основан на PostgreSQL 11.8 и Postgres Pro Enterprise 11.7.2. Все изменения, унаследованные от PostgreSQL 11.8, описаны в Замечаниях к выпуску PostgreSQL 11.8. По сравнению с Postgres Pro Enterprise 11.7.2 эта версия также содержит следующие изменения:

  • Устранено зацикливание планировщика, которое наблюдалось при операциях соединения со множеством условий IN и сопровождалось потреблением всей свободной памяти.

  • Устранена возможность сбоя сервера в случае обращения процесса автоочистки к удалённому вручную пространству имён.

  • Устранена ошибка, которая могла приводить к нарушению транзакционной целостности при использовании множества автономных транзакций.

  • Реализована замена нижележащего индекса для первичного ключа и ограничений-исключений с использованием предложения ALTER CONSTRAINT ... USING INDEX команды ALTER TABLE. Ранее эта функциональность поддерживалась только для уникальных ограничений. Помимо этого были улучшены проверки совместимости заменяемых индексов.

  • В CFS теперь можно изменять параметр cfs_gc_threshold в рамках текущего сеанса. Например, можно временно задать для него меньшее значение, если требуется отдельно дефрагментировать отношение, процент мусора в котором меньше глобально установленного предела.

  • Устранена утечка памяти, проявлявшаяся при операциях соединения, в которых требовалось оценивать множество путей выполнения для сложных запросов.

  • Добавлен параметр --no-data-checksums для initdb, позволяющий инициализировать кластеры Postgres Pro с отключёнными контрольными суммами.

  • Оптимизирована запись пустых страниц в файлы *.cfm при создании базовых копий.

  • Добавлена поддержка Oracle Linux 8.

  • Добавлена поддержка ОС Альт 8 СП.

  • Добавлена поддержка системы Ubuntu 20.04.

  • Добавлен пакет plpython3 для ОС Rosa Enterprise Linux Server и РОСА «КОБАЛЬТ» (серверная редакция) на платформе РОСА и AlterOS 7.5, где его раньше не было. Теперь он предоставляется для всех поддерживаемых платформ, кроме SLES 11.

  • Обновлено несколько библиотек, поставляемых с Postgres Pro для Windows, до следующих версий: OpenSSL 1.1.1g, libzstd 1.4.4, gettext 0.20.2, libiconv 1.16, libxml2 2.9.9 и libxslt 1.1.32. Библиотека ICU была обновлена с версии 56.1 до 56.2.

  • Обновлено расширение multimaster. В нём появилась функция mtm.check_query(query_text) для проверки согласованности данных на разных узлах кластера. За подробностями обратитесь к Подразделу F.30.4.6.

  • В расширении amcheck обеспечена корректная обработка индексов-B-деревьев с исключением дубликатов.

  • Расширение pgpro_scheduler обновлено до версии 2.6. В эту версию вошло несколько исправлений и улучшений, включая следующие:

    • Теперь выполнение команд DDL в запланированных заданиях не должно приводить к сбоям сервера.

    • pgpro_scheduler теперь запускает назначенные задания как только появляется доступный фоновый исполнитель, если в назначенное время свободных исполнителей не оказалось.

    • Полностью переработана реализация разбора заданий cron.

  • Расширение pageinspect обновлено до версии 1.6, теперь оно корректно обрабатывает 64-битные идентификаторы транзакций.

  • Обновлено расширение vops; теперь оно предоставляет автоматический способ формирования векторизованного представления данных и обращения к нему. За подробностями обратитесь к Подразделу F.68.5.5.

  • Расширение pg_pathman обновлено до версии 1.5.11. В данной версии устранена ошибка, возникавшая при попытке обращения к дочерним секциям, к которым нет доступа, при том, что к родительской таблице доступ разрешён. Эта проблема могла наблюдаться ранее при использовании pg_pathman с Postgres Pro 11.7.1 или новее.

E.21.2. Миграция на версию 11.8.1

Если вы производите обновление выпуска Postgres Pro Enterprise, базирующегося на той же основной версии PostgreSQL, достаточно просто установить новый выпуск в текущий каталог инсталляции.

Встроенные функции numeric_eq, numeric_ne, numeric_gt, numeric_ge, numeric_lt и numeric_le фактически являются герметичными, но они не имели соответствующей пометки в Postgres Pro Enterprise до версии 11.7.1, в результате чего запросы могли выполняться неоптимально. В частности, это отрицательно сказывалось на производительности запросов при использовании политик защиты на уровне строк. В версии 11.7.1 это было исправлено для новых инсталляций в результате корректировки исходных данных каталога, но существующие инсталляции сохранят некорректные пометки, пока вы не исправите записи этих функций в pg_proc. Чтобы их исправить, обновите экземпляр сервера с помощью pg_upgrade либо вручную измените их в существующем кластере, выполнив во всех его базах данных соответствующие команды ALTER FUNCTION. Например:

ALTER FUNCTION pg_catalog.numeric_eq LEAKPROOF

В версии 11.7.1 также исправлена работа регулярных выражений POSIX и конструкций SIMILAR TO, в которых применялись классы символов для правил сортировки ICU. Вследствие этого, возможно, стоит перепроверить объекты, использующие эти выражения.

Начиная с Postgres Pro Enterprise 11.6.1, обновление версии ICU не препятствует запуску сервера. Перед подключением к базе данных, в которой основное правило сортировки использует ICU, Postgres Pro сравнивает версию этого правила сортировки с версией, предоставляемой библиотекой ICU, и выдаёт предупреждения в случае несовпадения версий; если вы полагаете, что изменение версии правила сортировки может повлиять на порядок сортировки ваших данных, перестройте объекты, использующие основное правило сортировки. Чтобы убрать эти предупреждения, вы можете выполнить команду ALTER COLLATION "default" REFRESH VERSION, как описано в ALTER COLLATION.

Для перехода с PostgreSQL, а также с выпуска Postgres Pro Standard или Postgres Pro Enterprise, базирующегося на предыдущей основной версии PostgreSQL, обратитесь к инструкциям по миграции на версию 11.