Postgres Pro Standard 9.6.6.1: примечания к релизу

Этот выпуск основан на PostgreSQL 10.5.1 и PostgreSQL 9.6.5.

В число ключевых усовершенствований по сравнению с Postgres Pro 10.5.1 входят

  • Модуль pg_pathman обновлён до версии 1.4.8. (См. Раздел F.35 и Подраздел F.35.1.1.) Эта версия по сравнению с 1.4.3 включает следующие усовершенствования:

    • Улучшены механизмы сброса кеша.

    • Отключена команда COPY секционированная_таблица TO. Вместо неё используйте COPY (SELECT * FROM секционированная_таблица) TO.

    • Исправлена работа триггеров INSTEAD OF с представлениями, построенными по секционированным таблицам.

    • Команда ALTER TABLE секционированная_таблица RENAME TO теперь также переименовывает последовательности с автоматически сгенерированными именами.

    • Отключены некоторые опасные оптимизации команд SELECT ... FOR SHARE/UPDATE для PostgreSQL 9.5.

    • Улучшена обработка ошибок в фоновом процессе секционирования.

    • Запрещено выполнение запросов DELETE FROM секционированная_таблица_1 USING секционированная_таблица_2... и UPDATE секционированная_таблица_1 FROM секционированная_таблица_2..., если такие запросы затрагивают несколько секций таблицы секционированная_таблица_1.

    • Исправлена ошибка, приводящая к сбоям при выполнении RESET ALL.

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

    • Восстановлена совместимость с pg_repack.

    • Полный список изменений можно найти на вики-странице pg_pathman.

  • Утилита pg_probackup обновлена с версии 2.0.2 до 2.0.11, в которой появились новые возможности:

    • Правильно обрабатывается прерывание при вводе пароля.

    • Добавлена проверка, запрещающая пустые пароли.

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

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

    • Другие разнообразные исправления ошибок.

Миграция на версию 9.6.6.1

Процедура установки зависит от версии вашей текущей инсталляции.

Для обновления СУБД с версии Postgres Pro, основанной на предыдущем основном выпуске PostgreSQL, вы можете выполнить выгрузку/восстановление данных, применив pg_dumpall, или воспользоваться утилитой pg_upgrade. Первый вариант безопаснее, а второй быстрее и может значительно ускорить процесс обновления для больших баз данных.

Для обновления с версии Postgres Pro, основанной на этом же основном выпуске PostgreSQL, выгрузка/восстановление данных не требуется. Но вместо pg_upgrade вы должны использовать скрипт pgpro_upgrade, входящий в состав этого дистрибутивного набора. Этот скрипт обновляет метаданные как требуется в связи с изменением формата номера каталога, произошедшим в Postgres Pro 9.6.4.1. Если вы обновляете инсталляцию Postgres Pro, используя бинарный пакет, скрипт pgpro_upgrade запускается автоматически либо вам предлагается запустить его вручную.

Важно

Если вы запускаете pgpro_upgrade вручную, вы должны остановить службу postgres. Этот скрипт должен запускать пользователь-владелец базы данных (обычно postgres), а переменная окружения PGDATA должна указывать на каталог, где располагается база данных. При попытке запустить pgpro_upgrade от имени root произойдёт ошибка.

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

Примечание

В дистрибутивах Linux с системой пакетов RPM при обновлении с версии 9.6.2.1 или более ранней вы должны переименовать каталог данных pgsql в pgpro до запуска скрипта pgpro_upgrade.

Для перехода с ванильной версии PostgreSQL 9.6.x выполните выгрузку/восстановление данных, используя pg_dumpall.