E.8. Postgres Pro Enterprise 14.8.1

Дата выпуска: 2023-06-06

E.8.1. Обзор

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

  • Реализовано исключение дубликатов блокировок, которое позволяет эффективно хранить в памяти и отслеживать все исключительные блокировки, удерживаемые процессом запуска резервного сервера во время воспроизведения WAL.

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

  • Оптимизирован процесс сборки мусора в CFS: уменьшено потребление ресурсов процессора и количество чтений с диска при анализе файлов.

  • Добавлен параметр конфигурации unicode_nul_character_replacement_in_jsonb для замены '\u0000' заданным символом Unicode при вызове функции, обрабатывающей JSONB.

  • Улучшена производительность операций DDL с временными таблицами. Благодаря изменению механизма блокировки теперь при большом значении max_connections стоимость получения блокировок для таблиц с меткой ON COMMIT DELETE ROWS стала ниже.

  • Добавлен журнал операций, в котором хранится информация о критически важных системных событиях, таких как обновление, выполнение pg_resetwal и т. п. Эта информация важна для осуществления технической поддержки со стороны поставщика. Запись в журнал операций производится только на системном уровне, а для его чтения используются функции SQL. (См. Подраздел 9.27.12.)

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

  • Исправлена проблема, заключавшаяся в том, что файлы данных CFS на реплике были гораздо большего размера, чем на ведущем сервере. Теперь файлы на реплике записываются таким же образом, как на ведущем сервере, когда достигается согласованное состояние после восстановления.

  • Исправлена внутренняя ошибка, возникавшая в процессе удаления замкнутого соединения. Ранее не учитывалось, что при преобразовании выражения вида 'A.x=B.x' в 'A.x IS NOT NULL' необходимо корректировать метапараметры преобразованного выражения, поскольку оно имеет другую семантику. Исходное выражение может быть использовано в различных операциях, например, для выбора атрибута сортировки или в качестве выражения параметризации JOIN, что неприменимо к преобразованному.

  • Из файла postgresql.conf удалён признанный устаревшим параметр конфигурации cfs_gc_verify_file. Параметр конфигурации cfs_encryption также признан устаревшим и будет удалён в следующих выпусках.

  • Добавлена поддержка ОС РОСА «ХРОМ» 2021.2.

  • Прекращена поддержка системы Ubuntu 18.04.

  • Приложение mamonsu обновлено до версии 3.5.3, в которой были исправлены некоторые ошибки и появились новые возможности. Основные изменения перечислены ниже:

    • Удалено ограничение, которое не позволяло пользователям, кроме mamonsu, читать и редактировать файл конфигурации agent.conf. В частности, плагин pg_probackup теперь работает корректно, когда пользователь mamonsu является владельцем каталога резервных копий pg_probackup.

    • Удалены метрики, конфликтующие с собственными агентами Zabbix, из экспортируемого файла конфигурации Zabbix.

    • Исправлен выбор расширения по умолчанию для сбора статистики. Теперь, если установлены и pgpro_stats, и pg_stat_statements, pgpro_stats корректно выбирается как используемое по умолчанию.

    • Добавлена проверка того, что сервер, на котором работает плагин mamonsu WAL, не находится в режиме восстановления.

  • Из репликации multimaster исключены команды CREATE TABLESPACE и DROP TABLESPACE. Эти команды должны выполняться отдельно на каждом узле-партнёре.

  • Расширение pg_hint_plan обновлено до версии 1.4.1, в которой появился параметр hints_anywhere, позволяющий размещать указания в любом месте запроса.

  • Приложение pg_probackup обновлено до версии 2.6.4 Enterprise, в которой улучшена производительность и исправлены некоторые ошибки. Предыдущие версии несовместимы с Postgres Pro Enterprise версии 14.8.1. Основные изменения перечислены ниже:

    • Команда catchup, ранее доступная только в тестовом режиме, теперь доступна в производственной среде.

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

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

    • Повышена надёжность и устранены проблемы в операциях merge и backup с таблицами CFS.

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

    • Устранена ошибка в указании относительного пути после восстановления кластера из резервной копии.

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

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

    • Устранена проблема, из-за которой в инкрементальную резервную копию добавлялись все данные, а не только изменённые.

  • Приложение pgpro_stats обновлено до версии 1.6, в которой были исправлены некоторые ошибки и появились новые возможности:

    • Реализована трассировка сеансов приложений на основе фильтров, которые запускают протоколирование выполнения запросов, соответствующих условиям фильтрации. Вы можете использовать функции pgpro_stats для создания, изменения или удаления фильтров запросов. (За подробностями обратитесь к Подразделу F.45.6.1.)

    • Добавлены доступные только для суперпользователей функции, позволяющие создавать представления, которые эмулируют расширения pg_stat_statements и pg_stat_kcache. Можно создать представления pg_stat_statements, pg_stat_statements_info, pg_stat_kcache и pg_stat_kcache_detail. После этого с созданными представлениями можно работать так же, как если бы были установлены соответствующие расширения. (За подробностями обратитесь к Подразделу F.45.6.2.)

    • Добавлено представление pgpro_stats_archiver, которое расширяет системное представление pg_stat_archiver, добавляя к нему два новых поля: общее время, в течение которого процесс архивации был активен, и общее время, затраченное на выполнение команды архивации.

    • Добавлена обратная совместимость интерфейса статистик очистки. Теперь поддерживаются случаи, когда более новая версия загружаемого модуля pgpro_stats используется со старым объявлением SQL функций. Ранее подобные случаи вызывали крах сервера.

    • Устранены возможные сбои сервера, которые могли произойти из-за переполнения PGDATA, когда в расширении pgpro_stats выполнялся один или несколько длинных запросов. Теперь для хранения текстов запросов вместо временного файла, расположенного в каталоге PGDATA/pg_stat_tmp, можно использовать каталог с внешним файлом, установив значение параметра конфигурации pgpro_stats.stats_temp_directory. Можно установить это значение равным значению параметра конфигурации системы stats_temp_directory, но следует учитывать, что значение pgpro_stats.stats_temp_directory можно установить только при запуске сервера.

  • Приложение pgpro_pwr обновлено до версии 4.1.3, в которой добавлена поддержка расширения pgpro_stats версии 1.6 и появились новые возможности:

    • Добавлены таблицы отчётов «Top tables by removed all-visible/all-frozed marks» (Таблицы с наибольшим количеством удалённых меток полной видимости/заморозки).

    • Добавлено несколько новых полей в таблицу отчёта «Cluster Statistics» (Статистика кластера).

  • Расширение PTRACK обновлено до версии 2.4.3.

  • Модуль orafce обновлён до версии 4.2.6.

E.8.2. Миграция на версию 14.8.1

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

Если вы хотите сохранить существующее представление карт видимости в pageinspect при миграции на текущую основную версию Postgres Pro Enterprise с использованием pg_upgrade, выполните команду VACUUM, прежде чем начинать обновление.

При обновлении до версии Postgres Pro Enterprise 14.8.1 и выше обязательно обновите pg_probackup Enterprise до версии 2.6.4 или выше, поскольку более ранние версии pg_probackup несовместимы с этими версиями Postgres Pro Enterprise.

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