Postgresql установка


PostgreSQL : Документация: 9.6: 16.4. Процедура установки : Компания Postgres Professional

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

Заданная СТРОКА добавляется к номеру версии PostgreSQL. Это можно использовать, например, чтобы двоичные файлы, собранные из промежуточных снимков 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. Этот порт всегда можно изменить позже, но если вы укажете другой номер здесь, и сервер, и клиенты будут скомпилированы с одним значением, что очень удобно. Обычно менять это значение имеет смысл, только если вы намерены запускать в одной системе несколько серверов PostgreSQL.

--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-openssl

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

--with-pam

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

--with-bsd-auth

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

--with-ldap

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

--with-systemd

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

--without-readline

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

--with-libedit-preferred

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

--with-bonjour

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

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

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

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

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

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

--with-ossp-uuid

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

--with-libxml

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

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

--with-libxslt

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

--disable-integer-datetimes

Отключает применение 64-битных целых для хранения времени и интервалов, чтобы значения даты/времени хранились в виде чисел с плавающей точкой. Числа с плавающей точкой применялись для хранения дат/времени по умолчанию в PostgreSQL до версии 8.4, но сейчас этот вариант считается устаревшим, так как с ним не поддерживается точность до микросекунд во всём диапазоне значений timestamp. Однако для хранения таких значений в целочисленном виде требуется поддержка целочисленного 64-битного типа. Поэтому прежний вариант может использоваться, когда такой тип не поддерживается или для совместимости с приложениями, написанными для предыдущих версий PostgreSQL. Подробнее об этом можно узнать в Разделе 8.5.

--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 до 64 (в мегабайтах). Заметьте, что при изменении значения требуется выполнить initdb.

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

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

--disable-spinlocks

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

--disable-thread-safety

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

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

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

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

--without-zlib

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

--enable-debug

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

--enable-coverage

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

--enable-profiling

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

--enable-cassert

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

postgrespro.ru

PostgreSQL - установка и базовая настройка

PostgreSQL - мощная свободная объектно-реляционная система управления базами данных (СУБД). Базируется на языке SQL и поддерживает многие из возможностей стандарта SQL:2003.

Основные преимущества PostgreSQL:

  • поддержка БД практически неограниченного размера;
  • мощные и надёжные механизмы транзакций и репликации;
  • расширяемая система встроенных языков программирования;
  • масштабируемость.

Выполним установку из системы портов:

# cd /usr/ports/databases/postgresql92-server && make install clean && rehash

Опции сборки все оставил по умолчанию.

По завершению установки, порт вывел короткие рекомендации по дальнейшей настройке:

For procedural languages and postgresql functions, please note that you might have to update them when updating the server. If you have many tables and many clients running, consider raising kern.maxfiles using sysctl(8), or reconfigure your kernel appropriately. The port is set up to use autovacuum for new databases, but you might also want to vacuum and perhaps backup your database regularly. There is a periodic script, /usr/local/etc/periodic/daily/502.pgsql, that you may find useful. You can use it to backup and perfom vacuum on all databases nightly. Per default, it perfoms `vacuum analyze'. See the script for instructions. For autovacuum settings, please review ~pgsql/data/postgresql.conf. To allow many simultaneous connections to your PostgreSQL server, you should raise the SystemV shared memory limits in your kernel. Here are example values for allowing up to 180 clients (configurations in postgresql.conf also needed, of course): options SYSVSHM options SYSVSEM options SYSVMSG options SHMMAXPGS=65536 options SEMMNI=40 options SEMMNS=240 options SEMUME=40 options SEMMNU=120 If you plan to access your PostgreSQL server using ODBC, please consider running the SQL script /usr/local/share/postgresql/odbc.sql to get the functions required for ODBC compliance. Please note that if you use the rc script, /usr/local/etc/rc.d/postgresql, to initialize the database, unicode (UTF-8) will be used to store character data by default. Set postgresql_initdb_flags or use login.conf settings described below to alter this behaviour. See the start rc script for more info. To set limits, environment stuff like locale and collation and other things, you can set up a class in /etc/login.conf before initializing the database. Add something similar to this to /etc/login.conf: --- postgres:\ :lang=en_US.UTF-8:\ :setenv=LC_COLLATE=C:\ :tc=default: --- and run `cap_mkdb /etc/login.conf'. Then add 'postgresql_class="postgres"' to /etc/rc.conf. ====================================================================== To initialize the database, run /usr/local/etc/rc.d/postgresql initdb You can then start PostgreSQL by running: /usr/local/etc/rc.d/postgresql start For postmaster settings, see ~pgsql/data/postgresql.conf NB. FreeBSD's PostgreSQL port logs to syslog by default See ~pgsql/data/postgresql.conf for more info ====================================================================== To run PostgreSQL at startup, add 'postgresql_enable="YES"' to /etc/rc.conf ===> Installing rc.d startup script(s) ===> Correct pkg-plist sequence to create group(s) and user(s) ===> Registering installation for postgresql-server-9.2.b4 ===> SECURITY REPORT: This port has installed the following files which may act as network servers and may therefore pose a remote security risk to the system. /usr/local/bin/postgres This port has installed the following startup scripts which may cause these network services to be started at boot time. /usr/local/etc/rc.d/postgresql If there are vulnerabilities in these programs there may be a security risk to the system. FreeBSD makes no guarantee about the security of ports included in the Ports Collection. Please type 'make deinstall' to deinstall the port if this is a concern. For more information, and contact details about the security status of this software, see the following webpage: http://www.postgresql.org/

Поскольку PostgreSQL использует кодировку UTF-8 по умолчанию, для избежания проблем в дальнейшем, последуем совету и для пользователя pgsql (в новых версиях PostgreSQL работает от имени пользователя pgsql, а не postgres) немного подкорректируем локаль. Для этого в внесем такой блок в файл /etc/login.conf:

pgsql:\        :lang=en_US.UTF-8:\        :setenv=LC_COLLATE=C:\        :tc=default:

Далее:

# cap_mkdb /etc/login.conf

Базы данных будем размещать в каталоге /var/db/pgsql. Соответственно создадим необходимый каталог и выставим права доступа:

# mkdir /var/db/pgsql# chown pgsql:pgsql /var/db/pgsql

Вносим изменения в rc.conf, указывая каталог хранения данных. Ну и добавим запуск PostgreSQL при старте системы:

# echo '# PostgreSQL' >> /etc/rc.conf# echo 'postgresql_enable="YES"' >> /etc/rc.conf# echo 'postgresql_data="/var/db/pgsql"' >> /etc/rc.conf# echo 'postgresql_class="postgres"' >> /etc/rc.conf

После этих манипуляций выполним инициализацию базы данных:

# /usr/local/etc/rc.d/postgresql initdb

Скрипт по ходу своей работы будет выводить сообщения на консоль. Пример такого вывода:

The files belonging to this database system will be owned by user "pgsql". This user must also own the server process. The database cluster will be initialized with locale "C". The default text search configuration will be set to "english". fixing permissions on existing directory /var/db/pgsql ... ok creating subdirectories ... ok selecting default max_connections ... 100 selecting default shared_buffers ... 32MB creating configuration files ... ok creating template1 database in /var/db/pgsql/base/1 ... ok initializing pg_authid ... ok initializing dependencies ... ok creating system views ... ok loading system objects' descriptions ... ok creating collations ... not supported on this platform creating conversions ... ok creating dictionaries ... ok setting privileges on built-in objects ... ok creating information schema ... ok loading PL/pgSQL server-side language ... ok vacuuming database template1 ... ok copying template1 to template0 ... ok copying template1 to postgres ... ok WARNING: enabling "trust" authentication for local connections You can change this by editing pg_hba.conf or using the option -A, or --auth-local and --auth-host, the next time you run initdb. Success. You can now start the database server using: /usr/local/bin/postgres -D /var/db/pgsql or /usr/local/bin/pg_ctl -D /var/db/pgsql -l logfile start

После инициализации БД запускаем PostgreSQL сервер:

# sh /usr/local/etc/rc.d/postgresql start

После запуска проверяем состояние сервера:

# sh /usr/local/etc/rc.d/postgresql statuspg_ctl: server is running (PID: 30752)/usr/local/bin/postgres "-D" "/var/db/pgsql"

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

Сервер PosgreSQL предоставляет два варианта управления  пользователями и базами данных:

  • утилиты коммандной строки (createuser, createdb, dropuser, dropdb... )
  • интерактивный терминал

Воспользуемся интерактивным терминалом для настройки прав доступа. Подключимся от имени пользователся pgsql. Пароль не нужен.

# psql -U pgsql template1

psql (9.2beta4)Введите "help", чтобы получить справку.

template1=#

Наберем команду help и ознакомимся со справкой:

template1=# help

Вы используете psql - интерфейс командной строки к PostgreSQL. Азы: \copyright - условия распространения \h - справка по операторам SQL \? - справка по командам psql \g или ; в конце строки - выполнение запроса \q - выход

Советую ознакомиться со справкой по операторам SQL и командам psql. Теперь создадим тестового пользователя и базу данных, к которой он будет иметь доступ.

template1=# CREATE USER username;CREATE ROLE

Проверим список ролей:

template1-# \du

Список ролей Имя роли | Атрибуты | Член ролей ----------+---------------------------------------------------------+------------ pgsql | Суперпользователь, Создаёт роли, Создаёт БД, Репликация | {} username | | {}

Повысим созданному пользователю права доступа:

template1=# ALTER USER username superuser createrole createdb;ALTER ROLE

Повторно проверим список ролей:

template1=# \du

Список ролей Имя роли | Атрибуты | Член ролей ----------+---------------------------------------------------------+------------ pgsql | Суперпользователь, Создаёт роли, Создаёт БД, Репликация | {} username | Суперпользователь, Создаёт роли, Создаёт БД | {}

Обычному пользователю такие права ни к чему, их стоит выдавать только администратору системы. Отменим определенные права доступа:

template1=# ALTER USER username nosuperuser nocreaterole nocreatedb;ALTER ROLE

А вот пароли для пользователя - вещь обязательная. Зададим пароль для созданного пользователя:

template1=# \password usernameВведите новый пароль:Повторите его:

При вводе пароль не отображается! Также стоит установить пароль для пользователя pgsql. После этого включаем проверку пароля при подключении к PostgreSQL-серверу. Неоходимо внести изменения в файл /var/db/pgsql/pg_hba.conf. Метод подключения trust необходимо изменить на md5 (также полностью удаляем строку для IPv6). В результате имеем такой результат:

# TYPE DATABASE USER ADDRESS METHOD # "local" is for Unix domain socket connections only local all all md5 # IPv4 local connections: host all all 127.0.0.1/32 md5

Для того, чтобы изменения вступили в силу, необходимо перезапустить PostgreSQL-сервер:

# sh /usr/local/etc/rc.d/postgresql restart

Повторно подключаемся к интерактивной оболочке:

# psql -U pgsql template1Пароль пользователя pgsql:psql (9.2beta4)Введите "help", чтобы получить справку.

 

template1=#

Теперь сервер при подключении запрашивает пароль. Ну и напоследок создадим базу данных и дадим на нее права пользователю username. Сделать это можно двумя способами.

Первый способ:

template1=# CREATE DATABASE userdb owner=username;CREATE DATABASE

Второй способ:

template1=# CREATE DATABASE userdb;CREATE DATABASEtemplate1=# ALTER DATABASE userdb owner to username;ALTER DATABASE

Просмотрим список имеющихся баз данных:

template1=# \l

Список баз данных Имя | Владелец | Кодировка | LC_COLLATE | LC_CTYPE | Права доступа -----------+----------+-----------+------------+----------+----------------- postgres | pgsql | UTF8 | C | C | template0 | pgsql | UTF8 | C | C | =c/pgsql + | | | | | pgsql=CTc/pgsql template1 | pgsql | UTF8 | C | C | =c/pgsql + | | | | | pgsql=CTc/pgsql userdb | username | UTF8 | C | C | (4 строки)

В принципе, все интуитивно понятно. Используйте в своей работе документацию и подсказки, и работа с сервером PostgreSQL не должна вызывать больших проблем.

Последний штрих - тюнинг PostgreSQL-сервера. Все основные настройки хранятся в файле /var/db/pgsql/postgresql.conf. Отметим опции, на которые стоит обратить внимание (перевод описания опций взят здесь):

  • max_connections - максимальное количество одновременных подключений к серверу БД. Используйте этот параметр, чтобы не допустить запуска большого количества процессов сервера. Иначе есть вероятность, что серер БД исчерпает весь объем ОЗУ и будет активно использоваться подкачка, что в свою очередь повлечет за собой падение производительности.
  • shared_buffers - объем разделяемой памяти, используемый сервером БД. По умолчанию - 32 Мб, но может быть меньше, если настройки вашего ядра не позволяют выделить такой объем памяти, определяется при инициализации кластера БД утилитой initdb. Большие значения этого параметра положительно сказываются на производительности сервера БД.Если у вас выделенный компьютер с ОЗУ 1 Гб и больше под сервер БД, то хорошим значением этой переменной будет 25% от объема памяти. При большой нагрузке даже большие значения этого параметра могут быть эффективными, но так как PostgreSQL полагается на кэш ОС, то выделение более 40% от объема памяти вряд ли имеет смысл. Для больших значений этого параметра требуется так же увеличить значение параметра checkpoint_segments.На системах с ОЗУ меньше 1 Гб правильнее будет использовать меньший объем памяти (чем 25%), чтобы не исчерпать весь объем оперативной памяти. На винде большие значения этого параметра могут оказаться эффективными. Вы можете добиться большей производительности сохраняя это значение маленьким и больше используя средства кэширования ОС. Хорошим диапазоном значений для Windows является 64-512 Мб.
  • temp_buffers - максимальный размер временных буферов для каждой сессии. Эта память используется только локально в сессии для временных таблиц. По умолчанию - 8 МБ. Значение может быть изменено во время сессии, но только до первого использования этой памяти.
  • max_prepared_transactions - максимальное количество "prepared" транзакций (смотрите описание SQL команды PREPARE TRANSACTION в документации). Чтобы отключить эту фишку, поставьте значение в 0.
  • work_mem - определяет объем памяти, который будет использоваться внутренними операциями сортировки и хэш-таблицами прежде, чем переключиться на временные дисковые файлы. Учтите, что для сложных запросов несколько внутренних операций сортировки и работа с хэш-таблицами могут работать параллельно (одновременно). Кроме того, несколько сессий могут делать такие операции одновременно. В итоге необходимый объем памяти для этих операций может в несколько раз превышать значение параметра work_mem. Учтите это при выборе значения для этого параметра. Под внутренними операциями сортировки подразумевается - ORDER BY, DISTINCT и слияния.
  • maintenance_work_mem - максимальный объем памяти, используемый для внутренних операций, таких как VACUUM, CREATE INDEX и ALTER TABLE ADD FOREIGN KEY. По умолчанию - 16 Мб. Эти команды выполняются только во во время сессии, так что можно выбирать большие значения для этого параметра, чем для параметра work_mem. Большие значения могут положительно сказаться на производительности vacuuming и скорости восстановления БД из дампа. Только учтите, что процесс autovacuum запускается autovacuum_max_workers раз, поэтому может потребоваться больше свободной памяти.
  • max_stack_depth - максимальная глубина стека. Хорошим значением этого параметра является максимально разрешенная глубина стека в системе.
  • max_fsm_pages - с помощью этого параметра можно управлять картой свободного пространства. Когда что-то удаляется из таблицы, то место занимаемое этим что-то не освобождается на диске, вместо этого занимаемое место просто помечается как "свободно" в карте свободного пространства. Потом это место используется для новых записей. Если на вашем сервере очень много удаляется/добавляется данных из/в таблицы, то большие значения этого параметра могут положительно сказаться на производительности. 

     

muff.kiev.ua

Установка и настройка PostgreSQL | www.info-x.org

  • # -----------------------------
  • # Конфигурационный файл PostgreSQL
  • # -----------------------------
  • #
  • # Формат файла такой:
  • #
  • # name = value
  • #
  • # Знак "=" не обязателен, можно просто использовать пробел. Комментарии
  • # начинается со знака "#" и может находиться в любой части строки. Полный
  • # список возможных параметров можно найти в документации PostgreSQL.
  • #
  • # Прокомментированные настройки в этом файле инициализированы значениями
  • # по умолчанию. Не забывайте перезагружать сервер после изменения параметров.
  • #
  • # Этот файл читается при запуске сервера и при получении им сигнала
  • # SIGHUP. После редактирования конфигурационного файла вы должны
  • # послать сигнал SIGHUP серверу, чтобы он перечитал его и изменения
  • # вступили в силу (так же, вы можете использовать команду pg_ctl reload).
  • # Некоторые параметры, представленные ниже, требуют перезапуска сервера.
  • #
  • # Любой параметр также можно задать с помощью аргументов командной строки,
  • # например "postgres -c log_connections=on". Некоторые параметры можно
  • # задать во время сессии с помощью SQL команды "SET".
  • #
  • # Memory units: kB = kilobytes MB = megabytes GB = gigabytes
  • # Time units: ms = milliseconds s = seconds min = minutes h = hours d = days
  •  
  •  
  • #------------------------------------------------------------------------------
  • # Директории и файлы
  • #------------------------------------------------------------------------------
  •  
  • # Значения по умолчанию для этих опций передаются с помощью
  • # параметра командной строки -D или переменной окружения PGDATA,
  • # которая представлена здесь как ConfigDir.
  •  
  • #data_directory = 'ConfigDir' # путь до кластера БД
  • # (требуется перезагрузка)
  • #hba_file = 'ConfigDir/pg_hba.conf' # host-based authentication file
  • # (требуется перезагрузка)
  • #ident_file = 'ConfigDir/pg_ident.conf' # ident configuration file
  • # (требуется перезагрузка)
  •  
  • # Если этот параметр не задан, то PID файл создаваться не будет.
  • #external_pid_file = '(none)' # Записывать PID файл
  • # (требуется перезагрузка)
  •  
  •  
  • #------------------------------------------------------------------------------
  • # Подключения и аутентификация
  • #------------------------------------------------------------------------------
  •  
  • # - Параметры подключения -
  •  
  • listen_addresses = '*' # на каком IP адресе(ах) принимать подключения;
  • # список разделенный запятыми;
  • # по умолчанию 'localhost', '*' = all
  • # (требуется перезагрузка)
  • port = 5432 # (требуется перезагрузка)
  • max_connections = 30 # (требуется перезагрузка)
  • # Внимание: Увеличение значения параметра max_connections потребует
  • # приблизительно 400 байт в разделяемой памяти на подключение, плюс
  • # блокировка пространства (смотрите max_locks_per_transaction). Так же
  • # вы должны увеличить параметр shared_buffers, чтобы принимать больше
  • # подключений.
  • superuser_reserved_connections = 1 # (требуется перезагрузка)
  • #unix_socket_directory = '' # (требуется перезагрузка)
  • #unix_socket_group = '' # (требуется перезагрузка)
  • #unix_socket_permissions = 0777 # 0 вначале означает 8-ую систему счисления
  • # (требуется перезагрузка)
  • #bonjour_name = '' # По умолчанию - имя компьютера
  • # (требуется перезагрузка)
  •  
  • # - Безопасность и аутентификация -
  •  
  • authentication_timeout = 1min # 1s-600s
  • ssl = on # (требуется перезагрузка)
  • #ssl_ciphers = 'ALL:!ADH:!LOW:!EXP:!MD5:@STRENGTH' # allowed SSL ciphers
  • # (требуется перезагрузка)
  • #ssl_renegotiation_limit = 512MB # amount of data between renegotiations
  • password_encryption = on
  • #db_user_namespace = off
  •  
  • # Kerberos and GSSAPI
  • #krb_server_keyfile = '' # (требуется перезагрузка)
  • #krb_srvname = 'postgres' # (требуется перезагрузка, только Kerberos)
  • #krb_server_hostname = '' # пустая строка, значит любая запись keytab
  • # (требуется перезагрузка, только Kerberos)
  • #krb_caseins_users = off # (требуется перезагрузка)
  • #krb_realm = '' # (требуется перезагрузка)
  •  
  • # - TCP Keepalives -
  • # смотрите "man 7 tcp"
  •  
  • #tcp_keepalives_idle = 0 # TCP_KEEPIDLE, in seconds;
  • # 0 - использовать системное значение
  • #tcp_keepalives_interval = 0 # TCP_KEEPINTVL, in seconds;
  • # 0 - использовать системное значение
  • #tcp_keepalives_count = 0 # TCP_KEEPCNT;
  • # 0 - использовать системное значение
  •  
  •  
  • #------------------------------------------------------------------------------
  • # Использование ресурсов (кроме WAL)
  • #------------------------------------------------------------------------------
  •  
  • # - Память -
  •  
  • shared_buffers = 128MB # минимум 128kB или max_connections*16kB
  • # (требуется перезагрузка)
  • temp_buffers = 8MB # минимум 800kB
  • max_prepared_transactions = 0 # может быть 0 или больше
  • # (требуется перезагрузка)
  • # Внимание: Увеличение значения параметра max_prepared_transactions потребует
  • # приблизительно 600 байт в разделяемой памяти на подключение, плюс
  • # блокировка пространства (смотрите max_locks_per_transaction).
  • work_mem = 2MB # минимум 64kB
  • maintenance_work_mem = 16MB # минимум 1MB
  • max_stack_depth = 32MB # минимум 100kB
  •  
  • # - Карта свободного пространства -
  •  
  • max_fsm_pages = 179200 # минимум max_fsm_relations*16, 6 байт на каждую
  • # (требуется перезагрузка)
  • #max_fsm_relations = 1000 # минимум 100, ~70 байт на каждый
  • # (требуется перезагрузка)
  •  
  • # - Использование ядерных ресурсов -
  •  
  • #max_files_per_process = 1000 # минимум 25
  • # (требуется перезагрузка)
  • #shared_preload_libraries = '' # (требуется перезагрузка)
  •  
  • # - Cost-Based Vacuum Delay -
  •  
  • #vacuum_cost_delay = 0 # 0-1000 milliseconds
  • #vacuum_cost_page_hit = 1 # 0-10000 credits
  • #vacuum_cost_page_miss = 10 # 0-10000 credits
  • #vacuum_cost_page_dirty = 20 # 0-10000 credits
  • #vacuum_cost_limit = 200 # 1-10000 credits
  •  
  • # - Background Writer -
  •  
  • #bgwriter_delay = 200ms # 10-10000ms between rounds
  • #bgwriter_lru_maxpages = 100 # 0-1000 max buffers written/round
  • #bgwriter_lru_multiplier = 2.0 # 0-10.0 multipler on buffers scanned/round
  •  
  •  
  • #------------------------------------------------------------------------------
  • # Ведение лога
  • #------------------------------------------------------------------------------
  •  
  • # - Установки -
  •  
  • fsync = on # Вкл/выкл синхронизацию
  • synchronous_commit = on # Вызов fsync при коммите
  • wal_sync_method = fsync # the default is the first option
  • # supported by the operating system:
  • # open_datasync
  • # fdatasync
  • # fsync
  • # fsync_writethrough
  • # open_sync
  • full_page_writes = on # recover from partial page writes
  • wal_buffers = 128kB # минимум 32kB
  • # (требуется перезагрузка)
  • #wal_writer_delay = 200ms # 1-10000 milliseconds
  •  
  • #commit_delay = 0 # диапазон 0-100000, в микросекундах
  • #commit_siblings = 5 # диапазон 1-1000
  •  
  • # - Контрольные точки -
  •  
  • #checkpoint_segments = 3 # сегменты в лог файле, минимум 1, каждый 16MB
  • #checkpoint_timeout = 5min # диапазон 30s-1h
  • #checkpoint_completion_target = 0.5 # checkpoint target duration, 0.0 - 1.0
  • #checkpoint_warning = 30s # 0 is off
  •  
  • # - Архивирование -
  •  
  • archive_mode = off # разрешить архивирование
  • # (требуется перезагрузка)
  • #archive_command = '' # команда, используемая для архивирования сегментов
  • #archive_timeout = 0 # принудительно переключать сегмент в лог файле
  • # по истечению времени; 0 - выключено
  •  
  •  
  • #------------------------------------------------------------------------------
  • # Тюнинг планировщика запросов
  • #------------------------------------------------------------------------------
  •  
  • # - Конфигурация методов планирования -
  •  
  • enable_bitmapscan = on
  • enable_hashagg = on
  • enable_hashjoin = on
  • enable_indexscan = on
  • enable_mergejoin = on
  • enable_nestloop = on
  • enable_seqscan = on
  • enable_sort = on
  • enable_tidscan = on
  •  
  • # - Planner Cost Constants -
  •  
  • #seq_page_cost = 1.0 # measured on an arbitrary scale
  • #random_page_cost = 4.0 # same scale as above
  • #cpu_tuple_cost = 0.01 # same scale as above
  • #cpu_index_tuple_cost = 0.005 # same scale as above
  • #cpu_operator_cost = 0.0025 # same scale as above
  • #effective_cache_size = 128MB
  •  
  • # - Оптимизатор запросов -
  •  
  • geqo = on
  • #geqo_threshold = 12
  • #geqo_effort = 5 # диапазон 1-10
  • #geqo_pool_size = 0 # selects default based on effort
  • #geqo_generations = 0 # selects default based on effort
  • #geqo_selection_bias = 2.0 # диапазон 1.5-2.0
  •  
  • # - Другие параметры планировщика -
  •  
  • #default_statistics_target = 10 # диапазон 1-1000
  • #constraint_exclusion = off
  • #from_collapse_limit = 8
  • #join_collapse_limit = 8 # 1 disables collapsing of explicit
  • # JOIN clauses
  •  
  •  
  • #------------------------------------------------------------------------------
  • # Лог ошибок
  • #------------------------------------------------------------------------------
  •  
  • # - Куда слать логи -
  •  
  • #log_destination = 'syslog'
  • log_destination = 'stderr' # Возможные значение:
  • # stderr, csvlog, syslog and eventlog,
  • # зависят от платформы. csvlog
  • # требует, чтобы logging_collector был включен.
  •  
  • # This is used when logging to stderr:
  • logging_collector = on # Разрешить сбор сообщений с stderr или csvlog
  • # в лог файлы. Требуется для
  • # csvlogs.
  • # (требуется перезагрузка)
  •  
  • # Эти параметры используются только, если параметр logging_collector включен:
  • log_directory = 'pg_log' # директория - куда писать логи,
  • # может будь абсолютной или релятивной относительно PGDATA
  • log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log' # шаблон имени лог файла,
  • # можно использовать последовательности strftime()
  • #log_truncate_on_rotation = off # Если включено, то существующий файл будет
  • # очищен, а запись будет начата сначала файла.
  • # Файл будет очищаться только по срабатыванию
  • # таймера, то есть при перезапуске сервера или
  • # при достижении определенного размера,
  • # файл очищаться не будет. По умолчанию
  • # выключено, что означает дописывание
  • # в конец существующих файлов во всех случаях.
  • #log_rotation_age = 1d # Автоматическая ротация логов будет производиться
  • # по истечению заданного времени. 0 - выключено.
  • #log_rotation_size = 10MB # Автоматическая ротация логов будет производиться
  • # при достижении размера файла заданных размеров.
  • # 0 - выключено.
  •  
  • # Эти параметры имеют значение, если логи шлются в syslog:
  • #syslog_facility = 'LOCAL0'
  • #syslog_ident = 'postgres'
  •  
  •  
  • # - Уровень информативности -
  •  
  • #client_min_messages = notice # значения представлены в порядке
  • # понижения информативности:
  • # debug5
  • # debug4
  • # debug3
  • # debug2
  • # debug1
  • # log
  • # notice
  • # warning
  • # error
  •  
  • #log_min_messages = notice # values in order of decreasing detail:
  • # debug5
  • # debug4
  • # debug3
  • # debug2
  • # debug1
  • # info
  • # notice
  • # warning
  • # error
  • # log
  • # fatal
  • # panic
  •  
  • #log_error_verbosity = default # terse, default, or verbose messages
  •  
  • #log_min_error_statement = error # values in order of decreasing detail:
  • www.info-x.org