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

Этот выпуск основан на PostgreSQL 10.1 и включает все новые возможности, появившиеся в PostgreSQL 10, а также исправления ошибок, вошедшие в PostgreSQL 10.1. За подробным их описанием обратитесь к Замечаниям к выпуску PostgreSQL 10 и Замечаниям к выпуску PostgreSQL 10.1, соответственно. Другие важные изменения и улучшения:

  • Унифицирована структура пакетов двоичной установки для разных дистрибутивов Linux. Новая структура пакетов отличается от структуры ванильного PostgreSQL, но даёт следующие преимущества:

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

    • Теперь вы можете полностью управлять созданием базы данных по умолчанию во всех дистрибутивах Linux. Если вы устанавливаете пакет postgrespro-std-10, он разворачивает все пакеты Postgres Pro, необходимые для вашей системы, создаёт базу данных по умолчанию и настраивает сервер полностью автоматическим образом. Если вы устанавливаете отдельные пакеты, вам нужно настроить Postgres Pro самостоятельно. В этом случае вы должны вручную инициализировать кластер баз данных и запустить сервер, а также настроить автозапуск сервера, если требуется.

    • Вы можете установить Postgres Pro 10 рядом с другими продуктами на базе PostgreSQL для осуществления миграции или параллельного использования. Если вы выбираете отдельные пакеты, ваша системная конфигурация будет сохранена, так что вам придётся вручную настроить Postgres Pro, следуя инструкциям в Подразделе 16.1.3. Не устанавливайте пакет postgrespro-std-10 в системе, где уже установлен другой продукт на базе PostgreSQL, во избежание конфликтов.

    Заметьте, что пакеты postgrespro-common и postgrespro-client-common для систем на базе Debian теперь отсутствуют. За подробностями обратитесь к Разделу 16.1.

  • Возможность установки icu или libc в качестве провайдера правил сортировки по умолчанию при инициализации кластера баз данных или создании базы данных. По умолчанию для всех локалей, кроме C and POSIX, используется провайдер icu. За подробностями обратитесь к Подразделу 24.2.2.

  • В индексе-B-дереве дублирующиеся ключи теперь хранятся в единственном экземпляре, вместо дубликатов хранятся указатели на элементы в списке. Это может значительно сократить размер индекса, когда один ключ встречается многократно.

Ключевые доработки, перенесённые из Postgres Pro 9.6:

  • Доработки покрывающих индексов (За подробностями обратитесь к описанию предложения INCLUDE в CREATE INDEX.)

  • Исправления для системы сборки win32

  • Добавлена SQL-функция pgpro_version и соответствующие определения в pg_config.h

  • Внедрение механизма PTRACK

  • В psql для Windows включена поддержка редактирования командной строки с использованием libeditline

Из Postgres Pro 9.6 перенесены следующие модули и утилиты:

E.1.2. Миграция на версию 10.1.1

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

При миграции на Postgres Pro 10 не используйте пакет postgrespro-std-10 во избежание конфликтов. Используйте вместо него отдельные пакеты, как рассказывается в Главе 16.

Начиная с Postgres Pro версии 10, при инициализации кластера баз данных или при создании базы может быть задан провайдер правил сортировки по умолчанию, как описано в Подразделе 24.2.2. Вы должны учитывать это при обновлении до данной версии, чтобы избежать повреждения индексов или ограничений.

Важно

Если в вашей текущей инсталляции Postgres Pro используется ICU, не обновляйте версию библиотеки ICU. В противном случае обновление до Postgres Pro 10 будет невозможно.

Важно

Версии PostgreSQL 9.5 и 9.5.1, а также Postgres Pro 9.5.0.1 и 9.5.1.2 нельзя обновить непосредственно до Postgres Pro. Если вы используете такую версию, сначала обновите вашу инсталляцию до промежуточной версии, например, до Postgres Pro 9.5.2.1.

Следуя процедуре обновления с использованием pg_upgrade, убедитесь в том, что initdb устанавливает в новом кластере баз данных корректный провайдер правил сортировки по умолчанию:

  • Осуществляя миграцию с ванильного сервера PostgreSQL, укажите libc в качестве провайдера правил сортировки по умолчанию.

  • При обновлении Postgres Pro опустите указание провайдера правил сортировки по умолчанию, чтобы этот провайдер был выбран автоматически. В этом случае для баз данных с локалями C и POSIX, а также для любых баз данных с однобайтовыми кодировками будет использоваться провайдер libc, а для всех остальных — провайдер icu.

Если pg_upgrade создаёт какие-либо файлы SQL в текущем каталоге, запустите их для завершения обновления.

При обновлении с использованием pg_dumpall, Postgres Pro будет использовать провайдер правил сортировки, заданный при выполнении команды initdb для нового кластера. В этом случае индексы перестраиваются автоматически. Во избежание проблем с ограничениями, зависящими от правил сортировки, при обновлении с ванильного PostgreSQL рекомендуется использовать провайдер libc, а при обновлении с предыдущей версии Postgres Pro опустить указание провайдера.

Примечание

Если в предыдущей инсталляции Postgres Pro в базах с многобайтовыми кодировками имелись индексы или ограничения, зависящие от правил сортировки, отличных от C, POSIX или правила сортировки БД по умолчанию, в этих базах могли оказаться данные, нарушающие целостность индексов и условия ограничений. В Windows это также могло наблюдаться, если база данных с многобайтовой кодировкой содержала индексы или ограничения, зависящие от правила сортировки по умолчанию, имеющего длинное имя, например "Russian_Russia[.кодировка]" или "English_United States[.кодировка]". В таких случаях при обновлении Postgres Pro до версии 10 сценарий с выгрузкой/восстановлением данных может оказаться невозможным, и для обновления нужно будет использовать только pg_upgrade. Для устранения описанных проблем pg_upgrade объявляет такие индексы и ограничения нерабочими и создаёт скрипты reindex_text_indexes.sql и validate_text_contraints.sql, соответственно.

Осуществляя сборку Postgres Pro вручную, вы должны включить поддержку ICU, используя ключ --with-icu. В противном случае вы не сможете обновить предыдущую версию Postgres Pro до Postgres Pro 10.

Важно

При установке из двоичных пакетов в системах Linux изменены каталоги по умолчанию, по сравнению с Postgres Pro 9.6. Postgres Pro теперь устанавливается в каталог /opt/pgpro/std-10, а базы данных по умолчанию создаются в каталоге /var/lib/pgpro/std-10/data. Автозапуск сервера по умолчанию отключён. Учтите это, производя обновление до версии Postgres Pro 10. За подробностями обратитесь к Разделу 16.1.