E.14. Postgres Pro Standard 10.1.1

Дата выпуска: 2017-12-14

E.14.1. Обзор

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

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

    • Вам не нужно беспокоиться о специфике инсталляций в разных дистрибутивах Linux при миграции между различными поддерживаемыми системами Linux. Postgres Pro Standard теперь устанавливается в каталог /opt/pgpro/std-10, а база данных по умолчанию создаётся в каталоге /var/lib/pgpro/std-10/data.

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

    • Вы можете установить Postgres Pro Standard 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. За подробностями обратитесь к Подразделу 22.2.2.

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

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

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

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

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

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

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

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

E.14.2. Миграция на версию 10

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

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

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

Важно

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

Также, если вы используете версию Postgres Pro Standard 9.6.10.x в Windows, сначала обновите её до Postgres Pro Standard версии 9.6.11.1 или выше.

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

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

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

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

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

  • Если новый кластер инициализируется с локалью, отличной от C и POSIX, и при этом в базе используется однобайтовая кодировка, установите для этой базы в LC_COLLATE значение '@libc'.

  • Если новый кластер инициализируется с локалью C или POSIX, а в базе используется многобайтовая кодировка, установите для этой базы в LC_COLLATE значение '@icu'.

Примечание

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

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