17.3. Сборка и установка с использованием Autoconf и Make #
17.3.1. Краткий вариант #
./configure make su make install adduser postgres mkdir -p /usr/local/pgsql/data chown postgres /usr/local/pgsql/data su - postgres /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data /usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start /usr/local/pgsql/bin/createdb test /usr/local/pgsql/bin/psql test
Развёрнутый вариант представлен в продолжении этого раздела.
17.3.2. Процедура установки #
На первом шаге установки требуется сконфигурировать дерево установки для вашей системы и выбрать желаемые параметры сборки. Для этого нужно запустить скрипт
configure
. Чтобы выполнить стандартную сборку, просто введите:./configure
Этот скрипт проведёт несколько проверок с целью определить значения для различных переменных, зависящих от системы, и выявить любые странности вашей ОС, а затем создаст несколько файлов в дереве сборки, в которых отразит полученные результаты.
Вы также можете выполнить
configure
вне дерева исходного кода, если хотите сохранить каталог сборки отдельно. Эта процедура также называется сборкой с VPATH. Выполняется она так:mkdir build_dir
cd build_dir
/путь/к/каталогу/исходного/кода/configure [параметры]
make
В стандартной конфигурации собираются сервер и утилиты, а также клиентские приложения и интерфейсы, которым требуется только компилятор C. Все файлы по умолчанию устанавливаются в
/usr/local/pgsql
.Вы можете настроить процесс сборки и установки, передав
configure
один или несколько следующих параметров командной строки. Обычно настраивается место установки или набор дополнительных возможностей, включаемых при сборке. Скриптconfigure
принимает большое количество параметров, которые описаны в Подразделе 17.3.3.Кроме того,
configure
воспринимает ряд переменных окружения, описанных в Подраздел 17.3.4. Они дают возможность дополнительно настроить конфигурацию.Сборка
Чтобы запустить сборку, введите одну из двух команд:
make
make all
(Помните, что нужно использовать GNU make.) Сборка займёт несколько минут, в зависимости от мощности вашего компьютера.
Если вы хотите собрать всё, что может быть собрано, включая документацию (страницы HTML и man) и дополнительные модули (
contrib
), введите:make world
Если вы хотите собрать всё, что может быть собрано, включая дополнительные модули (
contrib
), но без документации, введите:make world-bin
Если вы хотите вызывать сборку из другого сборочного файла, а не вручную, вы должны сбросить переменную
MAKELEVEL
или присвоить ей 0, например так:build-postgresql: $(MAKE) -C postgresql MAKELEVEL=0 all
Если этого не сделать, могут выдаваться странные ошибки, обычно с сообщениями о недостающих заголовочных файлах.
Если вы хотите протестировать только что собранный сервер, прежде чем устанавливать его, на этом этапе вы можете запустить регрессионные тесты. Регрессионные тесты — это пакет тестов, проверяющих, что PostgreSQL работает на вашем компьютере так, как задумано разработчиками. Введите:
make check
(Это должен выполнять обычный пользователь, не root.) Как интерпретировать результаты проверки, подробно описывается в Главе 33. Вы можете повторить эту проверку позже в любой момент, выполнив ту же команду.
Установка файлов
Примечание
Если вы обновляете существующую систему, обязательно прочитайте инструкции по обновлению кластера, приведённые в Раздел 19.6.
Чтобы установить PostgreSQL, введите:
make install
При этом файлы будут установлены в каталоги, заданные в Шаг 1. Убедитесь в том, что у вас есть соответствующие разрешения для записи туда. Обычно это действие нужно выполнять от имени root. Также возможно заранее создать целевые каталоги и дать требуемый доступ к ним.
Чтобы установить документацию (HTML и страницы man), введите:
make install-docs
Если вы собирали цель world, введите вместо этого:
make install-world
При этом также будет установлена документация.
Если вы собирали цель world без документации, введите вместо этого:
make install-world-bin
Вы можете запустить
make install-strip
вместоmake install
, чтобы убрать лишнее из устанавливаемых исполняемых файлов и библиотек. Это позволит сэкономить немного места. Если вы выполняете сборку для отладки, при этом фактически вырежется поддержка отладки, поэтому этот вариант подходит только если отладка больше не планируется. Процедураinstall-strip
пытается оптимизировать объём разумными способами, но не рассчитывайте, что она способна удалить каждый ненужный байт из исполняемого файла. Если вы хотите освободить как можно больше места, вам придётся проделать это вручную.При стандартной установке в систему устанавливаются все заголовочные файлы для разработки клиентских приложений, а также программ на стороне сервера, в частности, собственных функций или типов данных, реализованных на C.
Установка только клиентской части: Если вы хотите установить только клиентские приложения и интерфейсные библиотеки, можно выполнить эти команды:
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
, прежде чем переконфигурировать и пересобирать всё заново. Если этого не сделать, ваши изменения в конфигурации могут распространиться не везде, где они важны.
17.3.3. Параметры configure
#
Параметры командной строки configure
описываются ниже. Этот список не является исчерпывающим (который можно получить, вызвав ./configure --help
). Неописанные здесь параметры предназначены для особых случаев, например для кросс-компиляции, и освещаются в стандартной документации Autoconf.
17.3.3.1. Место установки #
Эти параметры определяют, куда make install
будет устанавливать файлы. В большинстве случаев для определения целевого расположения достаточно параметра --prefix
. Если же у вас есть особые требования, вы можете установить разные целевые подкаталоги, воспользовавшись другими описанными здесь параметрами. Однако имейте в виду, что при изменении относительного расположения разных подкаталогов ваша инсталляция может оказаться неперемещаемой, то есть её нельзя будет перенести в другое место после развёртывания. (Это ограничение не касается расположения подкаталогов man
и doc
.) Для получения перемещаемой инсталляции может потребоваться параметр --disable-rpath
, описанный далее.
--prefix=
#ПРЕФИКС
Разместить все файлы внутри каталога
ПРЕФИКС
, а не в/usr/local/pgsql
. Собственно файлы будут установлены в различные подкаталоги этого каталога; в самом каталогеПРЕФИКС
никакие файлы не размещаются.--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, поставляемые в составе PostgreSQL, будут установлены в этот каталог, в соответствующие подкаталоги
man
. Значение по умолчанию —x
.DATAROOTDIR
/man--docdir=
#КАТАЛОГ
Задаёт корневой каталог для установки файлов документации, кроме страниц «man». Этот параметр только определяет базу для следующих параметров. Значение по умолчанию —
.DATAROOTDIR
/doc/postgresql--htmldir=
#КАТАЛОГ
В этот каталог будет помещена документация PostgreSQL в формате HTML. Значение по умолчанию —
.DATAROOTDIR
Примечание
Чтобы PostgreSQL можно было установить в стандартные системные размещения (например, в /usr/local/include
), не затрагивая пространство имён остальной системы, приняты определённые меры. Во-первых, к путям datadir
, sysconfdir
и docdir
автоматически добавляется строка «/postgresql
», если только полный развёрнутый путь каталога уже не содержит строку «postgres
» или «pgsql
». Так, если вы выберете в качестве префикса /usr/local
, документация будет установлена в /usr/local/doc/postgresql
, но с префиксом /opt/postgres
она будет помещена в /opt/postgres/doc
. Внешние заголовочные файлы C для клиентских интерфейсов устанавливаются в includedir
, не загрязняя пространство имён. Внутренние и серверные заголовочные файлы устанавливаются в частные подкаталоги внутри includedir
. Чтобы узнать, как обращаться к заголовочным файлам того или иного интерфейса, обратитесь к документации этого интерфейса. Наконец, для динамически загружаемых модулей, если требуется, будет также создан частный подкаталог внутри libdir
.
17.3.3.2. Функциональность PostgreSQL #
В этом разделе описаны параметры, включающую различную функциональность PostgreSQL, которая по умолчанию не собирается. Многие из этих компонентов не собираются по умолчанию, потому что требуют дополнительного программного обеспечения, о чём говорится в Разделе 17.1.
--enable-nls[=
#ЯЗЫКИ
]Включает поддержку национальных языков (NLS, Native Language Support), то есть возможность выводить сообщения программы не только на английском языке. Значение
ЯЗЫКИ
представляет необязательный список кодов языков через пробел, поддержка которых вам нужна, например:--enable-nls='de fr ru'
. (Пересечение заданного вами списка и множества действительно доступных переводов будет вычислено автоматически.) Если список не задаётся, устанавливаются все доступные переводы.Для использования этой возможности вам потребуется реализация API Gettext.
--with-perl
#Включает поддержку языка PL/Perl на стороне сервера.
--with-python
#Включает поддержку языка PL/Python на стороне сервера.
--with-tcl
#Включает поддержку языка PL/Tcl на стороне сервера.
--with-tclconfig=
#КАТАЛОГ
Tcl устанавливает файл
tclConfig.sh
, содержащий конфигурационные данные, необходимые для сборки модулей, взаимодействующих с Tcl. Этот файл обычно находится автоматически в известном размещении, но если вы хотите использовать другую версию Tcl, вы должны указать каталог, где искатьtclConfig.sh
.--with-llvm
#Включает поддержку JIT-компиляции (см. Главу 32) на базе LLVM. Для этого должна быть установлена библиотека LLVM. В настоящее время требуется версия LLVM не ниже 3.9.
Программа
llvm-config
будет использоваться для выяснения требуемых параметров компиляции. Поиск её будет выполняться в заданных путяхPATH
по имениllvm-config
, а затемllvm-config-$major-$minor
для всех поддерживаемых версий. Если нужную программу найти таким образом не удастся, воспользуйтесь переменнойLLVM_CONFIG
и укажите путь к корректномуllvm-config
. Например:./configure ... --with-llvm LLVM_CONFIG='/path/to/llvm/bin/llvm-config'
Для поддержки LLVM требуется совместимый компилятор
clang
(указываемый, если это требуется, в переменной окруженияCLANG
) и работающий компилятор C++ (указываемый, если требуется, в переменной окруженияCXX
).--with-lz4
#Собрать с поддержкой сжатия LZ4.
--with-zstd
#Собрать с поддержкой сжатия Zstandard.
--with-ssl=
#БИБЛИОТЕКА
Включает поддержку соединений SSL (зашифрованных). Единственной поддерживаемой
БИБЛИОТЕКОЙ
являетсяopenssl
. Для такой сборки необходимо установить пакет OpenSSL. Скриптconfigure
проверит наличие необходимых заголовочных файлов и библиотек, чтобы убедиться в целостности инсталляции OpenSSL до начала сборки.--with-openssl
#Устаревший вариант указания
--with-ssl=openssl
.--with-gssapi
#Включает поддержку аутентификации GSSAPI. Для GSSAPI необходимо установить MIT Kerberos. На многих платформах подсистема GSSAPI (входящая в состав MIT Kerberos) устанавливается не в то размещение, которое просматривается по умолчанию (например,
/usr/include
,/usr/lib
), так что помимо этого параметра вам придётся задать параметры--with-includes
и--with-libraries
. Скриптconfigure
проверит наличие необходимых заголовочных файлов и библиотек, чтобы убедиться в целостности инсталляции GSSAPI, прежде чем продолжить.--with-ldap
#Включает поддержку LDAP для проверки подлинности и получения параметров соединения (за дополнительными сведениями обратитесь к Разделу 34.18 и Разделу 21.10). В Unix для этого нужно установить пакет OpenLDAP. В Windows используется стандартная библиотека WinLDAP. Скрипт
configure
проверит наличие необходимых заголовочных файлов и библиотек, чтобы убедиться в целостности инсталляции OpenLDAP, прежде чем продолжить.--with-pam
#Включает поддержку PAM (Pluggable Authentication Modules, подключаемых модулей аутентификации).
--with-bsd-auth
#Включает поддержку аутентификации BSD. (Инфраструктура аутентификации BSD в настоящее время доступна только в OpenBSD.)
--with-systemd
#Включает поддержку служебных уведомлений для systemd. Это улучшает интеграцию с системой, когда сервер запускается под управлением systemd, и не оказывает никакого влияния в противном случае; за дополнительными сведениями обратитесь к Разделу 19.3. Для использования этой поддержки в системе должна быть установлена libsystemd с сопутствующими заголовочными файлами.
--with-bonjour
#Включает поддержку Bonjour, протокола автоматического обнаружения служб. Для этого Bonjour должен поддерживаться самой операционной системой. Рекомендуется для macOS.
--with-uuid=
#БИБЛИОТЕКА
Собрать модуль uuid-ossp (предоставляющий функции для генерирования UUID), используя заданную библиотеку UUID.
БИБЛИОТЕКА
может быть следующей:bsd
, чтобы использовались функции получения UUID, имеющиеся во FreeBSD и некоторых других системах на базе BSDe2fs
, чтобы использовалась библиотека получения UUID, созданная в рамках проектаe2fsprogs
; эта библиотека присутствует в большинстве систем Linux и macOS, также её можно найти и для других платформ.ossp
, чтобы использовалась библиотека OSSP UUID
--with-ossp-uuid
#Устаревший вариант указания
--with-uuid=ossp
.--with-libxml
#Собрать с libxml2, включая тем самым поддержку SQL/XML. Для этого требуется libxml версии 2.6.23 или новее.
Для определения нужных параметров компиляции и компоновки PostgreSQL обратится к
pkg-config
, если эта программа установлена, и запросит у неё информацию о libxml2. В противном случае будет вызвана программаxml2-config
, входящая в состав libxml2. Вариант сpkg-config
предпочтительнее, так как он лучше работает в конфигурации сборки для разных архитектур.Для использования libxml2 в нестандартном размещении вы можете задать переменные окружения для
pkg-config
(см. документацию pkg-config) или указать в переменной окруженияXML2_CONFIG
путь к программеxml2-config
, относящейся к нужной инсталляции libxml2, либо задать непосредственно переменныеXML2_CFLAGS
иXML2_LIBS
. (Если программаpkg-config
установлена, переопределить предоставляемую ей информацию о нахождении libxml2 можно, установив переменнуюXML2_CONFIG
или присвоив непустые значения обеим переменнымXML2_CFLAGS
иXML2_LIBS
.)--with-libxslt
#Собрать с libxslt, включая тем самым возможность выполнять XSL-преобразования XML-документов в модуле xml2. Для этого также должен быть указан ключ
--with-libxml
.
17.3.3.3. Отключение функциональности #
В этом разделе описаны параметры, отключающие некоторую функциональность PostgreSQL, которая по умолчанию собирается, но из-за отсутствия необходимого программного обеспечения или поддержки со стороны системы от неё нужно отказаться.
--without-icu
#Отключает поддержку библиотеки ICU, что отключает возможность использовать правила сортировки ICU (см. Раздел 24.2).
--without-readline
#Запрещает использование библиотеки Readline (а также libedit). При этом отключается редактирование командной строки и история в psql.
--with-libedit-preferred
#Отдаёт предпочтение библиотеке libedit с лицензией BSD, а не Readline (GPL). Этот параметр имеет значение, только если установлены обе библиотеки; по умолчанию в этом случае используется Readline.
--without-zlib
#Запрещает использование библиотеки Zlib. При этом отключается поддержка сжатых архивов утилитами pg_dump и pg_restore.
--disable-spinlocks
#Позволяет провести сборку, если PostgreSQL не может воспользоваться циклическими блокировками CPU на данной платформе. Отсутствие таких блокировок приводит к кардинальному снижению производительности, поэтому использовать этот вариант следует, только если сборка прерывается и выдаётся сообщение, что ваша платформа эти блокировки не поддерживает. Если вы не можете собрать PostgreSQL на вашей платформе без этого указания, сообщите о данной проблеме разработчикам PostgreSQL.
--disable-atomics
#Отключает использование атомарных операций процессора. На архитектурах, где такие операции отсутствуют, этот параметр никак не действует. Там же, где они поддерживаются, отказ от их использования приведёт к падению производительности. Этот параметр полезен только для отладки и для сравнительной оценки быстродействия.
--disable-thread-safety
#Отключает потокобезопасное поведение клиентских библиотек. При этом параллельные потоки программ на базе libpq и ECPG не будут безопасно контролировать собственные дескрипторы соединений. Используйте это только на тех платформах, где отсутствует полноценная поддержка потоков.
17.3.3.4. Особенности процесса сборки #
--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
.--with-system-tzdata=
#КАТАЛОГ
В PostgreSQL включена собственная база данных часовых поясов, необходимая для операций с датой и временем. На самом деле эта база данных совместима с базой часовых поясов IANA, поставляемой в составе многих операционных систем FreeBSD, Linux, Solaris, поэтому устанавливать её дополнительно может быть излишне. С этим параметром вместо базы данных, включённой в пакет исходного кода PostgreSQL, будет использоваться системная база данных часовых поясов, находящаяся в заданном
КАТАЛОГЕ
.КАТАЛОГ
должен задаваться абсолютным путём (в ряде операционных систем принят путь/usr/share/zoneinfo
). Заметьте, что процедура установки не будет проверять несоответствия или ошибки в данных часовых поясов. Поэтому, используя этот параметр, рекомендуется выполнить регрессионные тесты, чтобы убедиться, что выбранная вами база данных часовых поясов работает корректно с PostgreSQL.Этот параметр в основном предназначен для тех, кто собирает двоичные пакеты для дистрибутивов и хорошо знает свою операционную систему. Основной плюс от использования системных данных в том, что пакет PostgreSQL не придётся обновлять при изменениях местных определений часовых поясов. Ещё один плюс заключается в упрощении кросс-компиляции, так как при инсталляции не требуется собирать базу данных часовых поясов.
--with-extra-version=
#СТРОКА
Заданная
СТРОКА
добавляется к номеру версии PostgreSQL. Это можно использовать, например, чтобы двоичные файлы, собранные из промежуточных снимков Git или кода с дополнительными правками, отличались от стандартных дополнительной строкой в версии, например, содержащей идентификаторgit describe
или номер выпуска дистрибутивного пакета.--disable-rpath
#Не добавлять в исполняемые файлы PostgreSQL атрибут, с которым они будут искать разделяемые библиотеки в каталоге библиотек инсталляции (см.
--libdir
). На большинстве платформ этот атрибут задаёт абсолютный путь к каталогу библиотек, поэтому этот вариант не подходит, если вы намерены перемещать готовую инсталляцию. Однако вам в любом случае нужно каким-то образом указать, где исполняемые файлы могут найти разделяемые библиотеки. Обычно для этого нужно настроить механизм динамического связывания в операционной системе, указав нужный каталог библиотек; за подробностями обратитесь к Подразделу 17.5.1.
17.3.3.5. Разное #
Из следующих параметров чаще всего применяется, особенно в тестовых сборках, параметр --with-pgport
, позволяющий изменить номер порта по умолчанию. Другие описанные в этом разделе параметры рекомендуется использовать только опытным пользователям.
--with-pgport=
#НОМЕР
Задаёт
НОМЕР
порта по умолчанию для сервера и клиентов. Стандартное значение — 5432. Этот порт всегда можно изменить позже, но если вы укажете другой номер здесь, и сервер, и клиенты будут скомпилированы с одним значением, что очень удобно. Обычно менять это значение имеет смысл, только если вы намерены запускать в одной системе несколько серверов PostgreSQL.--with-krb-srvnam=
#ИМЯ
Задаёт имя по умолчанию для субъекта-службы Kerberos, используемое GSSAPI (по умолчанию это
postgres
). Обычно менять его имеет смысл только в сборке для среды Windows, где оно должно быть задано в верхнем регистре (POSTGRES
).--with-segsize=
#РАЗМЕР_СЕГМЕНТА
Задаёт размер сегмента (в гигабайтах). Сервер делит большие таблицы на несколько файлов в файловой системе, ограничивая размер каждого данным размером сегмента. Это позволяет обойти ограничения на размер файлов, существующие на многих платформах. Размер сегмента по умолчанию, 1 гигабайт, безопасен для всех поддерживаемых платформ. Если же ваша операционная система поддерживает «большие файлы» (а сегодня это поддерживают почти все), вы можете установить больший размер сегмента. Это позволит уменьшить число файловых дескрипторов, используемых при работе с очень большими таблицами. Но будьте осторожны, чтобы выбранное значение не превысило максимум, поддерживаемый вашей платформой и файловыми системами, которые вы будете применять. Возможно, допустимый размер файла будет ограничиваться и другими утилитами, которые вы захотите использовать, например tar. Рекомендуется, хотя и не требуется, чтобы это значение было степенью 2. Заметьте, что с изменением этого значения нарушается совместимость формата базы на диске, то есть вы не сможете использовать
pg_upgrade
для перехода к сборке с другим размером сегмента.--with-blocksize=
#РАЗМЕР_БЛОКА
Задаёт размер блока (в килобайтах). Эта величина будет единицей хранения и ввода/вывода данных таблиц. Значение по умолчанию, 8 килобайт, достаточно универсально; но в особых случаях может быть оправдан другой размер блока. Это значение должно быть степенью 2 от 1 до 32 (в килобайтах). Заметьте, что с изменением этого значения нарушается совместимость формата базы на диске, то есть вы не сможете использовать
pg_upgrade
для перехода к сборке с другим размером блока.--with-wal-blocksize=
#РАЗМЕР_БЛОКА
Задаёт размер блока WAL (в килобайтах) Эта величина будет единицей хранения и ввода/вывода записей WAL. Значение по умолчанию, 8 килобайт, достаточно универсально; но в особых случаях может быть оправдан другой размер блока. Это значение должно быть степенью 2 от 1 до 64 (в килобайтах). Заметьте, что с изменением этого значения нарушается совместимость формата базы на диске, то есть вы не сможете использовать
pg_upgrade
для перехода к сборке с другим размером блока WAL.
17.3.3.6. Параметры для разработчиков #
Большинство параметров в этом разделе имеют ценность только для разработки или отладки PostgreSQL. Использовать их в производственных сборках не рекомендуется, кроме, возможно, ключа --enable-debug
, позволяющего получить подробную информацию об ошибке, в случае, если вы столкнётесь с проблемой. На платформах, поддерживающих DTrace, также может иметь смысл использовать для производственной сборки --enable-dtrace
.
При сборке инсталляции, которая будет использоваться для отладки внутреннего кода сервера, рекомендуется как минимум использовать параметры --enable-debug
и --enable-cassert
.
--enable-debug
#Включает компиляцию всех программ и библиотек с отладочными символами. Это значит, что вы сможете запускать программы в отладчике для анализа проблем. При такой компиляции размер установленных исполняемых файлов значительно увеличивается, а компиляторы, кроме GCC, обычно отключают оптимизацию, что снижает быстродействие. Однако наличие отладочных символов очень полезно при решении возможных проблем любой сложности. В настоящее время рекомендуется использовать этот параметр для производственной среды, только если применяется компилятор GCC. Но если вы занимаетесь разработкой или испытываете бета-версию, его следует использовать всегда.
--enable-cassert
#Включает для сервера проверочные утверждения, проверяющие множество условий, которые «не должны происходить». Это бесценно в процессе разработки кода, но эти проверки могут значительно замедлить работу сервера. Кроме того, включение этих проверок не обязательно увеличит стабильность вашего сервера! Проверочные утверждения не категоризируются по важности, поэтому относительно безвредная ошибка может привести к перезапуску сервера, если утверждение не выполнится. Применять это следует, только если вы занимаетесь разработкой или испытываете бета-версию, но не в производственной среде.
--enable-tap-tests
#Включает тесты по технологии Perl TAP. Для этого у вас должен быть установлен Perl и модуль
IPC::Run
. За дополнительными сведениями обратитесь к Разделу 33.4.--enable-depend
#Включает автоматическое отслеживание зависимостей. С этим параметром скрипты Makefile настраиваются так, чтобы при изменении любого заголовочного файла пересобирались все зависимые объектные файлы. Это полезно в процессе разработки, но если вам нужно только скомпилировать и установить сервер, это будет лишней тратой времени. В настоящее время это работает только с GCC.
--enable-coverage
#При использовании GCC все программы и библиотеки компилируются с инструментарием, оценивающим покрытие кода тестами. Если его запустить, в каталоге сборки будут сформированы файлы с метриками покрытия кода. За дополнительными сведениями обратитесь к Разделу 33.5. Этот параметр предназначен только для GCC и только для использования в процессе разработки.
--enable-profiling
#При использовании GCC все программы и библиотеки компилируются так, чтобы их можно было профилировать. В результате по завершении серверного процесса будет создаваться подкаталог с файлом
gmon.out
, содержащим данные для профилирования. Этот параметр предназначен только для GCC и только для тех, кто занимается разработкой.--enable-dtrace
#Включает при компиляции PostgreSQL поддержку средства динамической трассировки DTrace. За дополнительными сведениями обратитесь к Разделу 28.5.
Задать расположение программы
dtrace
можно в переменной окруженияDTRACE
. Часто это необходимо, потому чтоdtrace
обычно устанавливается в каталог/usr/sbin
, который может отсутствовать вPATH
.Дополнительные параметры командной строки для
dtrace
можно задать в переменной окруженияDTRACEFLAGS
. В Solaris, чтобы включить поддержку DTrace для 64-битной сборки, необходимо передать параметрDTRACEFLAGS="-64"
. Например, с компилятором GCC:./configure CC='gcc -m64' --enable-dtrace DTRACEFLAGS='-64' ...
С компилятором Sun:
./configure CC='/opt/SUNWspro/bin/cc -xtarget=native64' --enable-dtrace DTRACEFLAGS='-64' ...
--with-segsize-blocks=SEGSIZE_BLOCKS
#Указывает размер сегмента отношения в блоках. Если указан и данный параметр, и
--with-segsize
, применяется данный параметр. Он предназначен только для разработчиков и позволяет тестировать код, связанный с сегментом.
17.3.4. Переменные окружения для configure
#
Помимо описанных выше обычных парамеров командной строки скрипт configure
воспринимает ряд переменных окружения. Эти переменные можно задать в командной строке configure
, например так:
./configure CC=/opt/bin/gcc CFLAGS='-O2 -pipe'
При таком указании переменная окружения несколько отличается от параметра командной строки. Также можно задать переменные окружения предварительно:
export CC=/opt/bin/gcc
export CFLAGS='-O2 -pipe'
./configure
Этот вариант может быть удобнее, так как параметры, заданные таким образом, могут восприниматься конфигурационными скриптами многих программ в одном ключе.
Из описанных здесь переменных окружения чаще всего используются CC
и CFLAGS
. Если вы предпочитаете компилятор C, отличный от выбираемого скриптом configure
, укажите его в переменной CC
. По умолчанию configure
выбирает gcc
(если он находится) или стандартный компилятор платформы (обычно cc
). Подобным образом при необходимости можно переопределить флаги компилятора по умолчанию с помощью переменной CFLAGS
.
Ниже приведён список значимых переменных, которые можно установить таким образом:
BISON
#программа Bison
CC
#компилятор C
CFLAGS
#параметры, передаваемые компилятору C
CLANG
#путь к программе
clang
, которая будет подготавливать исходный код для встраивания при компиляции с ключом--with-llvm
CPP
#препроцессор C
CPPFLAGS
#параметры, передаваемые препроцессору C
CXX
#компилятор C++
CXXFLAGS
#параметры, передаваемые компилятору C++
DTRACE
#расположение программы
dtrace
DTRACEFLAGS
#параметры, передаваемые программе
dtrace
FLEX
#программа Flex
LDFLAGS
#параметры, которые должны использоваться при компоновке исполняемых программ или разделяемых библиотек
LDFLAGS_EX
#дополнительные параметры для компоновки только исполняемых программ
LDFLAGS_SL
#дополнительные параметры для компоновки только разделяемых библиотек
LLVM_CONFIG
#программа
llvm-config
, помогающая найти инсталляцию LLVMMSGFMT
#расположение программы
msgfmt
для поддержки национальных языковPERL
#Команда, вызывающая интерпретатор Perl. Она помогает определить зависимости для сборки PL/Perl. Значение по умолчанию —
perl
.PYTHON
#Команда, вызывающая интерпретатор Python. Она нужна для определения зависимостей при сборке PL/Python. Если это значение не определено, в указанном порядке перебираются следующие варианты:
python3 python
.TCLSH
#Команда, вызывающая интерпретатор Tcl. Она помогает определить зависимости для сборки PL/Tcl. Если она не задана, в указанном порядке перебираются следующие варианты:
tclsh tcl tclsh8.6 tclsh86 tclsh8.5 tclsh85 tclsh8.4 tclsh84
.XML2_CONFIG
#программа
xml2-config
, помогающая найти инсталляцию libxml2
Иногда может быть полезно добавить флаги компилятора к набору флагов, ранее заданному на этапе configure
. В частности, эта потребность объясняется тем, что параметр gcc -Werror
нельзя указать в переменной CFLAGS
, передаваемой configure
, так как в результате сломаются многие встроенные тесты configure
. Чтобы добавить такие флаги, задайте их в переменной среды COPT
при запуске make
. Содержимое COPT
будет добавлено в параметры CFLAGS
и LDFLAGS
, заданные скриптом configure
. Например, вы можете выполнить:
make COPT='-Werror'
или
export COPT='-Werror'
make
Примечание
Используя GCC, лучше выполнять сборку с уровнем оптимизации не ниже -O1
, так как без оптимизации (-O0
) отключаются некоторые важные предупреждения компилятора (например, об использовании неинициализированных переменных). Однако оптимизация ненулевого уровня может затруднить отладку, так как при пошаговом выполнении скомпилированный код обычно не соответствует в точности строкам исходного кода. При возникновении сложностей с отладкой оптимизированного кода, перекомпилируйте интересующие вас файлы с ключом -O0
. Это можно сделать, просто передав соответствующий параметр make: make PROFILE=-O0 file.o
.
На самом деле переменные окружения COPT
и PROFILE
обрабатываются сборочными файлами Makefile PostgreSQL одинаково. Поэтому выбор одной из этих переменных — дело вкуса, но обычно разработчики используют PROFILE
для одноразовых корректив флагов, а содержимое COPT
сохраняют постоянным.