17.4. Процедура установки

  1. Конфигурирование

    На первом шаге установки требуется сконфигурировать дерево установки для вашей системы и выбрать желаемые параметры сборки. Для этого нужно запустить скрипт configure. Чтобы выполнить стандартную сборку, просто введите:

    ./configure
    

    Этот скрипт проведёт несколько проверок с целью определить значения для различных переменных, зависящих от системы, и выявить любые странности вашей ОС, а затем создаст несколько файлов в дереве сборки, в которых отразит полученные результаты. Вы также можете выполнить configure вне дерева исходного кода, если хотите сохранить каталог сборки отдельно. Эта процедура также называется сборкой с VPATH. Выполняется она так:

    mkdir build_dir
    cd build_dir
    /путь/к/каталогу/исходного/кода/configure [параметры]
    make
    

    В стандартной конфигурации собираются сервер и утилиты, а также клиентские приложения и интерфейсы, которым требуется только компилятор C. Все файлы по умолчанию устанавливаются в /usr/local/pgsql.

    Вы можете настроить процесс сборки и установки, передав configure один или несколько следующих параметров командной строки:

    --prefix=ПРЕФИКС

    Разместить все файлы внутри каталога ПРЕФИКС, а не в /usr/local/pgsql. Собственно файлы будут установлены в различные подкаталоги этого каталога; в самом каталоге ПРЕФИКС никакие файлы не размещаются.

    Если у вас есть особые требования, вы также можете изменить отдельные подкаталоги, определив следующие параметры. Однако, если вы оставите для них значения по умолчанию, инсталляция будет перемещаемой, то есть вы сможете переместить каталог после установки. (Это не распространяется на каталоги man и doc.)

    Для перемещаемых инсталляций можно передать configure указание --disable-rpath. Кроме того, вы должны будете сказать операционной системе, как найти разделяемые библиотеки.

    --exec-prefix=ИСП-ПРЕФИКС

    Вы можете установить архитектурно-зависимые файлы в размещение с другим префиксом, ИСП-ПРЕФИКС, отличным от ПРЕФИКС. Это бывает полезно для совместного использования таких файлов несколькими системами. По умолчанию ИСП-ПРЕФИКС считается равным ПРЕФИКС и все файлы, архитектурно-зависимые и независимые, устанавливаются в одно дерево каталогов, что вам скорее всего и нужно.

    --bindir=КАТАЛОГ

    Задаёт каталог для исполняемых двоичных программ. По умолчанию это ИСП-ПРЕФИКС/bin, что обычно означает /usr/local/pgsql/bin.

    --sysconfdir=КАТАЛОГ

    Задаёт каталог для различных файлов конфигурации, ПРЕФИКС/etc по умолчанию.

    --libdir=КАТАЛОГ

    Задаёт каталог для установки библиотек и динамически загружаемых модулей. Значение по умолчанию — ИСП-ПРЕФИКС/lib.

    --includedir=КАТАЛОГ

    Задаёт каталог для установки заголовочных файлов C и C++. Значение по умолчанию — ПРЕФИКС/include.

    --datarootdir=КАТАЛОГ

    Задаёт корневой каталог для разного рода статических файлов. Этот параметр определяет только базу для некоторых из следующих параметров. Значение по умолчанию — ПРЕФИКС/share.

    --datadir=КАТАЛОГ

    Задаёт каталог для статических файлов данных, используемых установленными программами. Значение по умолчанию — DATAROOTDIR. Заметьте, что это совсем не тот каталог, в котором будут размещены файлы базы данных.

    --localedir=КАТАЛОГ

    Задаёт каталог для установки данных локализации, в частности, каталогов перевода сообщений. Значение по умолчанию — DATAROOTDIR/locale.

    --mandir=КАТАЛОГ

    Страницы man, поставляемые в составе Postgres Pro, будут установлены в этот каталог, в соответствующие подкаталоги manx. Значение по умолчанию — DATAROOTDIR/man.

    --docdir=КАТАЛОГ

    Задаёт корневой каталог для установки файлов документации, кроме страниц «man». Этот параметр только определяет базу для следующих параметров. Значение по умолчанию — DATAROOTDIR/doc/postgresql.

    --htmldir=КАТАЛОГ

    В этот каталог будет помещена документация Postgres Pro в формате HTML. Значение по умолчанию — DATAROOTDIR.

    Примечание

    Чтобы Postgres Pro можно было установить в стандартные системные размещения (например, в /usr/local/include), не затрагивая пространство имён остальной системы, приняты определённые меры. Во-первых, к путям datadir, sysconfdir и docdir автоматически добавляется строка «/postgresql», если только полный развёрнутый путь каталога уже не содержит строку «postgres» или «pgsql». Так, если вы выберете в качестве префикса /usr/local, документация будет установлена в /usr/local/doc/postgresql, но с префиксом /opt/postgres она будет помещена в /opt/postgres/doc. Внешние заголовочные файлы C для клиентских интерфейсов устанавливаются в includedir, не загрязняя пространство имён. Внутренние и серверные заголовочные файлы устанавливаются в частные подкаталоги внутри includedir. Чтобы узнать, как обращаться к заголовочным файлам того или иного интерфейса, обратитесь к документации этого интерфейса. Наконец, для динамически загружаемых модулей, если требуется, будет также создан частный подкаталог внутри libdir.

    --with-extra-version=СТРОКА

    Заданная СТРОКА добавляется к номеру версии Postgres Pro. Это можно использовать, например, чтобы двоичные файлы, собранные из промежуточных снимков Git или кода с дополнительными правками, отличались от стандартных дополнительной строкой в версии, например, содержащей идентификатор git describe или номер выпуска дистрибутивного пакета.

    --with-includes=КАТАЛОГИ

    Значение КАТАЛОГИ представляет список каталогов через двоеточие, которые будут просмотрены компилятором при поиске заголовочных файлов. Если дополнительные пакеты (например, GNU Readline) установлены у вас в нестандартное расположение, вам придётся использовать этот параметр и, возможно, также добавить соответствующий параметр --with-libraries.

    Пример: --with-includes=/opt/gnu/include:/usr/sup/include.

    --with-libraries=КАТАЛОГИ

    Значение КАТАЛОГИ представляет список каталогов через двоеточие, в котором следует искать библиотеки. Возможно, вам потребуется использовать этот параметр (и соответствующий --with-includes), если какие-то пакеты установлены у вас в нестандартное размещение.

    Пример: --with-libraries=/opt/gnu/lib:/usr/sup/lib.

    --enable-nls[=ЯЗЫКИ]

    Включает поддержку национальных языков (NLS, Native Language Support), то есть возможность выводить сообщения программы не только на английском языке. Значение ЯЗЫКИ представляет необязательный список кодов языков через пробел, поддержка которых вам нужна, например: --enable-nls='de fr ru'. (Пересечение заданного вами списка и множества действительно доступных переводов будет вычислено автоматически.) Если список не задаётся, устанавливаются все доступные переводы.

    Для использования этой возможности вам потребуется реализация API Gettext; см. выше.

    --with-pgport=НОМЕР

    Задаёт НОМЕР порта по умолчанию для сервера и клиентов. Стандартное значение — 5432. Этот порт всегда можно изменить позже, но если вы укажете другой номер здесь, и сервер, и клиенты будут скомпилированы с одним значением, что очень удобно. Обычно менять это значение имеет смысл, только если вы намерены запускать в одной системе несколько серверов Postgres Pro.

    --with-perl

    Включает поддержку языка PL/Perl на стороне сервера.

    --with-python

    Включает поддержку языка PL/Python на стороне сервера.

    --with-tcl

    Включает поддержку языка PL/Tcl на стороне сервера.

    --with-tclconfig=КАТАЛОГ

    Tcl устанавливает файл tclConfig.sh, содержащий конфигурационные данные, необходимые для сборки модулей, взаимодействующих с Tcl. Этот файл обычно находится автоматически в известном размещении, но если вы хотите использовать другую версию Tcl, вы должны указать каталог, где искать этот файл.

    --with-gssapi

    Включает поддержку аутентификации GSSAPI. На многих платформах подсистема GSSAPI (обычно входящая в состав Kerberos) устанавливается не в то размещение, которое просматривается по умолчанию (например, /usr/include, /usr/lib), так что помимо этого параметра вам придётся задать параметры --with-includes и --with-libraries. Скрипт configure проверит наличие необходимых заголовочных файлов и библиотек, чтобы убедиться в целостности инсталляции GSSAPI, прежде чем продолжить.

    --with-krb-srvnam=ИМЯ

    Задаёт имя по умолчанию для субъекта-службы Kerberos, используемое GSSAPI (по умолчанию это postgres). Обычно менять его имеет смысл только в среде Windows, где оно должно быть задано в верхнем регистре (POSTGRES).

    --with-icu

    Включает поддержку библиотеки ICU. Для этого должен быть установлен пакет ICU4C. В настоящее время требуется ICU4C версии не ниже 4.2.

    По умолчанию для определения нужных параметров компиляции будет использоваться pkg-config. Этот вариант работает для ICU4C версии 4.6 и новее. Для более старых версий или в отсутствие pkg-config соответствующие параметры для configure можно задать в переменных ICU_CFLAGS и ICU_LIBS, как в этом примере:

    ./configure ... --with-icu ICU_CFLAGS='-I/путь/include' ICU_LIBS='-L/путь/lib -licui18n -licuuc -licudata'

    (Даже если ICU4C находится в пути поиска, который использует компилятор, тем не менее нужно задать непустое значение, чтобы избежать обращения к pkg-config, например, ICU_CFLAGS=' '.)

    --with-openssl

    Включает поддержку соединений SSL (зашифрованных). Для этого необходимо установить пакет OpenSSL. Скрипт configure проверит наличие необходимых заголовочных файлов и библиотек, чтобы убедиться в целостности инсталляции OpenSSL, прежде чем продолжить.

    --with-pam

    Включает поддержку PAM (Pluggable Authentication Modules, подключаемых модулей аутентификации).

    --with-bsd-auth

    Включает поддержку аутентификации BSD. (Инфраструктура аутентификации BSD в настоящее время доступна только в OpenBSD.)

    --with-ldap

    Включает поддержку LDAP для проверки подлинности и получения параметров соединения (за дополнительными сведениями обратитесь к Разделу 34.17 и Подразделу 21.3.7). В Unix для этого нужно установить пакет OpenLDAP. В Windows используется стандартная библиотека WinLDAP. Скрипт configure проверит наличие необходимых заголовочных файлов и библиотек, чтобы убедиться в целостности инсталляции OpenLDAP, прежде чем продолжить.

    --with-systemd

    Включает поддержку служебных уведомлений для systemd. Это улучшает интеграцию с системой, когда процесс сервера запускается под управлением systemd, и не оказывает никакого влияния в противном случае; за дополнительными сведениями обратитесь к Разделу 19.3. Для использования этой поддержки в системе должна быть установлена libsystemd с сопутствующими заголовочными файлами.

    --without-readline

    Запрещает использование библиотеки Readline (а также libedit). При этом отключается редактирование командной строки и история в psql, так что этот вариант не рекомендуется.

    --with-libedit-preferred

    Отдаёт предпочтение библиотеке libedit с лицензией BSD, а не Readline (GPL). Этот параметр имеет значение, только если установлены обе библиотеки; по умолчанию в этом случае используется Readline.

    --with-bonjour

    Включает поддержку Bonjour. Для этого Bonjour должен поддерживаться самой операционной системой. Рекомендуется для macOS.

    --with-uuid=БИБЛИОТЕКА

    Собрать модуль uuid-ossp (предоставляющий функции для генерирования UUID. БИБЛИОТЕКА может быть следующей:

    • bsd, чтобы использовались функции получения UUID, имеющиеся во FreeBSD, NetBSD и некоторых других системах на базе BSD

    • e2fs, чтобы использовалась библиотека получения UUID, созданная в рамках проекта e2fsprogs; эта библиотека присутствует в большинстве систем Linux и macOS, также её можно найти и для других платформ.

    • ossp, чтобы использовалась библиотека OSSP UUID

    --with-ossp-uuid

    Устаревший вариант указания --with-uuid=ossp.

    --with-libxml

    Собрать с libxml (включает поддержку SQL/XML). Для этого требуется libxml версии 2.6.23 или новее.

    В составе libxml устанавливается программа xml2-config, с помощью которой можно получить требуемые параметры компилятора и компоновщика. Postgres Pro будет использовать её автоматически, если найдёт. Чтобы указать нестандартное размещение libxml, вы можете воспользоваться переменной окружения XML2_CONFIG и указать в ней путь к программе xml2-config нужной инсталляции, либо задать параметры --with-includes и --with-libraries.

    --with-libxslt

    Использовать libxslt при сборке модуля xml2. Библиотека xml2 задействует её для выполнения XSL-преобразований XML.

    --disable-float4-byval

    Запрещает передачу типа float4 «по значению», чтобы он передавался «по ссылке». Это снижает быстродействие, но может быть необходимо для совместимости со старыми пользовательскими функциями на языке C, которые используют соглашение о вызовах «версии 0». В качестве более долгосрочного решения лучше модернизировать такие функции, чтобы они использовали соглашение «версии 1».

    --disable-float8-byval

    Запрещает передачу типа float8 «по значению», чтобы он передавался «по ссылке». Это снижает быстродействие, но может быть необходимо для совместимости со старыми пользовательскими функциями на языке C, которые используют соглашение о вызовах «версии 0». В качестве более долгосрочного решения лучше модернизировать такие функции, чтобы они использовали соглашение «версии 1». Заметьте, что этот параметр влияет не только на float8, но и на int8, а также некоторые другие типы, например timestamp. На 32-битных платформах параметр --disable-float8-byval действует по умолчанию и задать --enable-float8-byval нельзя.

    --with-segsize=РАЗМЕР_СЕГМЕНТА

    Задаёт размер сегмента (в гигабайтах). Сервер делит большие таблицы на несколько файлов в файловой системе, ограничивая размер каждого данным размером сегмента. Это позволяет обойти ограничения на размер файлов, существующие на многих платформах. Размер сегмента по умолчанию, 1 гигабайт, безопасен для всех поддерживаемых платформ. Если же ваша операционная система поддерживает «большие файлы» (а сегодня это поддерживают почти все), вы можете установить больший размер сегмента. Это позволит уменьшить число файловых дескрипторов, используемых при работе с очень большими таблицами. Но будьте осторожны, чтобы выбранное значение не превысило максимум, поддерживаемый вашей платформой и файловыми системами, которые вы будете применять. Возможно, допустимый размер файла будет ограничиваться и другими утилитами, которые вы захотите использовать, например tar. Рекомендуется, хотя и не требуется, чтобы это значение было степенью 2. Заметьте, что при изменении значения требуется выполнить initdb.

    --with-blocksize=РАЗМЕР_БЛОКА

    Задаёт размер блока (в килобайтах). Эта величина будет единицей хранения и ввода/вывода данных таблиц. Значение по умолчанию, 8 килобайт, достаточно универсально; но в особых случаях может быть оправдан другой размер блока. Это значение должно быть степенью 2 от 1 до 32 (в килобайтах). Заметьте, что при изменении значения требуется выполнить initdb.

    --with-wal-segsize=РАЗМЕР_СЕГМЕНТА

    Задаёт размер сегмента WAL (в мегабайтах). Эта величина определяет размер каждого отдельного файла журнала WAL. Изменять этот размер бывает полезно для оптимизации фрагментации при трансляции журналов. Значение по умолчанию — 16 мегабайт. Значение должно задаваться степенью 2 от 1 до 1024 (в мегабайтах). Заметьте, что при изменении значения требуется выполнить initdb.

    --with-wal-blocksize=РАЗМЕР_БЛОКА

    Задаёт размер блока WAL (в килобайтах) Эта величина будет единицей хранения и ввода/вывода записей WAL. Значение по умолчанию, 8 килобайт, достаточно универсально; но в особых случаях может быть оправдан другой размер блока. Это значение должно быть степенью 2 от 1 до 64 (в килобайтах). Заметьте, что при изменении значения требуется выполнить initdb.

    --disable-spinlocks

    Позволяет провести сборку, если Postgres Pro не может воспользоваться циклическими блокировками CPU на данной платформе. Отсутствие таких блокировок приводит к снижению производительности, поэтому использовать этот вариант следует, только если сборка прерывается и выдаётся сообщение, что ваша платформа эти блокировки не поддерживает. Если вы не можете собрать Postgres Pro на вашей платформе без этого указания, сообщите о данной проблеме разработчикам Postgres Pro.

    --disable-strong-random

    Разрешает производить сборку, даже если в Postgres Pro отсутствует поддержка генерирования криптографически стойких случайных ключей на данной платформе. Источник случайных чисел необходим для некоторых протоколов аутентификации, а также некоторых функций в модуле pgcrypto. Ключ --disable-strong-random отключает функциональность, требующую криптографически стойкие случайные числа, и задействует для получения соли и ключей отмены запросов слабый генератор псевдослучайных чисел. Это может сделать аутентификацию менее безопасной.

    --disable-thread-safety

    Отключает потокобезопасное поведение клиентских библиотек. При этом параллельные потоки программ на базе libpq и ECPG не будут безопасно контролировать собственные дескрипторы соединений.

    --with-system-tzdata=КАТАЛОГ

    В Postgres Pro включена собственная база данных часовых поясов, необходимая для операций с датой и временем. На самом деле эта база данных совместима с базой часовых поясов IANA, поставляемой в составе многих операционных систем FreeBSD, Linux, Solaris, поэтому устанавливать её дополнительно может быть излишне. С этим параметром вместо базы данных, включённой в пакет исходного кода Postgres Pro, будет использоваться системная база данных часовых поясов, находящаяся в заданном КАТАЛОГЕ. КАТАЛОГ должен задаваться абсолютным путём (в ряде операционных систем принят путь /usr/share/zoneinfo). Заметьте, что процедура установки не будет проверять несоответствия или ошибки в данных часовых поясов. Поэтому, используя этот параметр, рекомендуется выполнить регрессионные тесты, чтобы убедиться, что выбранная вами база данных часовых поясов работает корректно с Postgres Pro.

    Этот параметр в основном предназначен для тех, кто собирает двоичные пакеты для дистрибутивов и хорошо знает свою операционную систему. Основной плюс от использования системных данных в том, что пакет Postgres Pro не придётся обновлять при изменениях местных определений часовых поясов. Ещё один плюс заключается в упрощении кросс-компиляции, так как при инсталляции не требуется собирать базу данных часовых поясов.

    --without-zlib

    Запрещает использование библиотеки Zlib. При этом отключается поддержка сжатых архивов утилитами pg_dump и pg_restore. Этот параметр предназначен только для тех редких систем, в которых нет этой библиотеки.

    --enable-debug

    Включает компиляцию всех программ и библиотек с отладочными символами. Это значит, что вы сможете запускать программы в отладчике для анализа проблем. При такой компиляции размер установленных исполняемых файлов значительно увеличивается, а компиляторы, кроме GCC, обычно отключают оптимизацию, что снижает быстродействие. Однако, наличие отладочных символов очень полезно при решении возможных проблем любой сложности. В настоящее время рекомендуется использовать этот параметр для производственной среды, только если применяется компилятор GCC. Но если вы занимаетесь разработкой или испытываете бета-версию, его следует использовать всегда.

    --enable-coverage

    При использовании GCC все программы и библиотеки компилируются с инструментарием, оценивающим покрытие кода тестами. Если его запустить, в каталоге сборки будут сформированы файлы с метриками покрытия кода. За дополнительными сведениями обратитесь к Разделу 33.5. Этот параметр предназначен только для GCC и только для использования в процессе разработки.

    --enable-profiling

    При использовании GCC все программы и библиотеки компилируются так, чтобы их можно было профилировать. В результате по завершении серверного процесса будет создаваться подкаталог с файлом gmon.out для профилирования. Этот параметр предназначен только для GCC и только для тех, кто занимается разработкой.

    --enable-cassert

    Включает для сервера проверочные утверждения, проверяющие множество условий, которые «не должны происходить». Это бесценно в процессе разработке кода, но эти проверки могут значительно замедлить работу сервера. Кроме того, включение этих проверок не обязательно увеличит стабильность вашего сервера! Проверочные утверждения не категоризируются по важности, поэтому относительно безвредная ошибка может привести к перезапуску сервера, если утверждение не выполнится. Применять это следует, только если вы занимаетесь разработкой или испытываете бета-версию, но не в производственной среде.

    --enable-depend

    Включает автоматическое отслеживание зависимостей. С этим параметром скрипты Makefile настраиваются так, чтобы при изменении любого заголовочного файла пересобирались все зависимые объектные файлы. Это полезно в процессе разработки, но если вам нужно только скомпилировать и установить сервер, это будет лишней тратой времени. В настоящее время это работает только с GCC.

    --enable-dtrace

    Включает при компиляции Postgres Pro поддержку средства динамической трассировки DTrace. За дополнительными сведениями обратитесь к Разделу 29.5.

    Задать расположение программы dtrace можно в переменной окружения DTRACE. Часто это необходимо, потому что dtrace обычно устанавливается в каталог /usr/sbin, который может отсутствовать в пути поиска.

    Дополнительные параметры командной строки для dtrace можно задать в переменной окружения DTRACEFLAGS. В Solaris, чтобы включить поддержку DTrace для 64-битной сборки, необходимо передать configure параметр DTRACEFLAGS="-64". Например, с компилятором GCC:

    ./configure CC='gcc -m64' --enable-dtrace DTRACEFLAGS='-64' ...
    

    С компилятором Sun:

    ./configure CC='/opt/SUNWspro/bin/cc -xtarget=native64' --enable-dtrace DTRACEFLAGS='-64' ...
    
    --enable-tap-tests

    Включает тесты по технологии Perl TAP. Для этого у вас должен быть установлен Perl и модуль IPC::Run. За дополнительными сведениями обратитесь к Разделу 33.4.

    Если вы предпочитаете компилятор C, отличный от выбираемого скриптом configure, укажите его в переменной CC. По умолчанию configure выбирает gcc (если он находится) или стандартный компилятор платформы (обычно cc). Подобным образом, при необходимости можно переопределить флаги компилятора по умолчанию с помощью переменной CFLAGS.

    Вы можете задать переменные окружения в командной строке configure, например, так:

    ./configure CC=/opt/bin/gcc CFLAGS='-O2 -pipe'
    

    Ниже приведён список значимых переменных, которые можно установить таким образом:

    BISON

    Программа Bison

    CC

    компилятор C

    CFLAGS

    параметры, передаваемые компилятору C

    CPP

    препроцессор C

    CPPFLAGS

    параметры, передаваемые препроцессору C

    DTRACE

    расположение программы dtrace

    DTRACEFLAGS

    параметры, передаваемые программе dtrace

    FLEX

    программа Flex

    LDFLAGS

    параметры, которые должны использоваться при компоновке исполняемых программ или разделяемых библиотек

    LDFLAGS_EX

    дополнительные параметры для компоновки только исполняемых программ

    LDFLAGS_SL

    дополнительные параметры для компоновки только разделяемых библиотек

    MSGFMT

    расположение программы msgfmt для поддержки национальных языков

    PERL

    Полный путь к интерпретатору Perl. Он нужен для определения зависимостей при сборке PL/Perl.

    PYTHON

    Полный путь к интерпретатору Python. Он нужен для определения зависимостей при сборке PL/Python. Кроме того, версия Python, 2 или 3, выбранная таким образом (или неявно как-то ещё), определяет вариацию языка PL/Python, которая будет доступна. За дополнительными сведениями обратитесь к Разделу 46.1.

    TCLSH

    Полный путь к интерпретатору Tcl. Он нужен для определения зависимостей при сборке PL/Tcl и будет подставляться в скрипты Tcl.

    XML2_CONFIG

    Программа xml2-config помогает найти инсталляцию libxml.

    Иногда может быть полезно добавить флаги компилятора к набору флагов, ранее заданному на этапе configure. В частности, эта потребность объясняется тем, что параметр gcc -Werror нельзя указать в переменной CFLAGS, передаваемой configure, так как в результате сломаются многие встроенные тесты configure. Чтобы добавить такие флаги, задайте их в переменной среды COPT при запуске make. Содержимое COPT будет добавлено в параметры CFLAGS и LDFLAGS, заданные скриптом configure. Например, вы можете выполнить:

    make COPT='-Werror'
    

    или

    export COPT='-Werror'
    make
    

    Примечание

    Разрабатывая внутренний код сервера, рекомендуется использовать указания configure --enable-cassert (которое включает множество проверок во время выполнения) и --enable-debug (которое упрощает использование средств отладки).

    Используя GCC, лучше выполнять сборку с уровнем оптимизации не ниже -O1, так как без оптимизации (-O0) отключаются некоторые важные предупреждения компилятора (например, об использовании неинициализированных переменных). Однако оптимизация ненулевого уровня может затруднить отладку, так как при пошаговом выполнении скомпилированный код обычно не соответствует в точности строкам исходного кода. При возникновении сложностей с отладкой оптимизированного кода, перекомпилируйте интересующие вас файлы с ключом -O0. Это можно сделать, просто передав соответствующий параметр make: make PROFILE=-O0 file.o.

    На самом деле переменные окружения COPT и PROFILE обрабатываются сборочными файлами Makefile PostgreSQL одинаково. Поэтому выбор одной из этих переменных — дело вкуса, но обычно разработчики используют PROFILE для одноразовых корректив флагов, а содержимое COPT сохраняют постоянным.

  2. Сборка

    Чтобы запустить сборку, введите:

    make
    

    (Помните, что нужно использовать GNU make.) Сборка займёт несколько минут, в зависимости от мощности вашего компьютера. В конце должно появиться сообщение:

    All of Postgres Pro successfully made. Ready to install.
    

    (Весь Postgres Pro собран успешно и готов к установке.)

    Если вы хотите собрать всё, что может быть собрано, включая документацию (страницы HTML и man) и дополнительные модули (contrib), введите:

    make world
    

    В конце должно появиться сообщение:

    Postgres Pro, contrib and documentation successfully made. Ready to install.
    

    (Postgres Pro, contrib и документация собраны успешно и готовы к установке.)

  3. Регрессионные тесты

    Если вы хотите протестировать только что собранный сервер, прежде чем устанавливать его, на этом этапе вы можете запустить регрессионные тесты. Регрессионные тесты — это комплектов тестов, проверяющих, что Postgres Pro работает на вашем компьютере так, как задумано разработчиками. Введите:

    make check
    

    (Это должен выполнять обычный пользователь, не root.) Как интерпретировать результаты проверки, подробно описывается в Главе 33. Вы можете повторить эту проверку позже в любой момент, выполнив ту же команду.

  4. Установка файлов

    Примечание

    Если вы обновляете существующую систему, обязательно прочитайте инструкции по обновлению кластера, приведённые в Разделе 19.6.

    Чтобы установить Postgres Pro, введите:

    make install
    

    При этом файлы будут установлены в каталоги, заданные в Шаг 1. Убедитесь в том, что у вас есть соответствующие разрешения для записи туда. Обычно это действие нужно выполнять от имени root. Также возможно заранее создать целевые каталоги и дать требуемый доступ к ним.

    Чтобы установить документацию (HTML и страницы man), введите:

    make install-docs
    

    Если вы собирали цель world, введите вместо этого:

    make install-world
    

    При этом также будет установлена документация.

    Вы можете запустить make install-strip вместо make install, чтобы убрать лишнее из устанавливаемых исполняемых файлов и библиотек. Это позволит сэкономить немного места. Если вы выполняете сборку для отладки, при этом фактически вырежется поддержка отладки, поэтому этот вариант подходит только если отладка больше не планируется. Процедура install-strip пытается оптимизировать объём разумными способами, но не рассчитывайте, что она способна удалить каждый ненужный байт из исполняемого файла. Если вы хотите освободить как можно больше места, вам придётся проделать это вручную.

    При стандартной установке в систему устанавливаются все заголовочные файлы для разработки клиентских приложений, а также программ на стороне сервера, в частности, собственных функций или типов данных, реализованных на C. (До PostgreSQL 8.0 для этого требовалось выполнить make install-all-headers, но сейчас это включено в стандартную установку.)

    Установка только клиентской части: Если вы хотите установить только клиентские приложения и интерфейсные библиотеки, можно выполнить эти команды:

    make -C src/bin install
    make -C src/include install
    make -C src/interfaces install
    make -C doc install
    

    В src/bin есть несколько программ, применимых только на сервере, но они очень малы.

Удаление: Чтобы отменить установку, воспользуйтесь командой make uninstall. Однако созданные каталоги при этом удалены не будут.

Очистка: После установки вы можете освободить место на диске, удалив файлы сборки из дерева исходного кода, выполнив make clean. При этом файлы, созданные программой configure, будут сохранены, так что позже вы сможете пересобрать всё заново, выполнив make. Чтобы сбросить дерево исходного кода к состоянию, в котором оно распространяется, выполните make distclean. Если вы намерены выполнять сборку одного дерева исходного кода для нескольких платформ, вам придётся делать это и переконфигурировать сборочную среду для каждой. (Также можно использовать отдельное дерево сборки для каждой платформы, чтобы дерево исходного кода оставалось неизменным.)

Если в процессе сборки вы обнаружите, что заданные вами параметры configure оказались ошибочными, либо вы изменили что-то, от чего зависит работа configure (например, обновили пакеты), стоит выполнить make distclean, прежде чем переконфигурировать и пересобирать всё заново. Если этого не сделать, ваши изменения в конфигурации могут распространиться не везде, где они важны.