Чтобы обеспечить поддержку решений 1C, дистрибутив Postgres Pro содержит следующие встроенные модули, которые включены по умолчанию и не требуют дополнительной настройки:
fasttrun — предоставляет транзакционно-небезопасную функцию для усечения временных таблиц, предотвращающую увеличение размера pg_class.
fulleq — предоставляет дополнительный оператор равенства для совместимости с Microsoft SQL Server.
mchar — предоставляет дополнительные типы данных MCHAR и MVARCHAR для совместимости с Microsoft SQL Server.
dbcopies_decoding — модуль 1C для обновления копий баз данных, который включён по умолчанию. Для использования механизма логической репликации этого модуля установите для параметра wal_level значение logical.
За более подробной информацией об этом модуле обратитесь в поддержку 1C.
Модуль plantuner позволяет оптимизировать планы выполнения запросов. Чтобы настроить его для решений 1C, выполните следующее:
Добавьте имя библиотеки в переменную shared_preload_libraries в файле postgresql.conf.
shared_preload_libraries = 'plantuner'
Установите для параметра plantuner.fix_empty_table значение on для улучшения планирования запросов с недавно созданными пустыми таблицами.
plantuner.fix_empty_table = on
Модуль online_analyze предоставляет набор функций, которые немедленно обновляют статистику для задействованных таблиц после операций INSERT, UPDATE, DELETE, SELECT INTO или COPY.
Не рекомендуется использовать этот модуль с современными версиями 1C.
Однако online_analyze можно включить, если фоновые изменения не обеспечивают ожидаемые результаты или оптимизатор часто ошибается в оценке количества строк.
Следующая инструкция полезна, только если вы решите использовать этот модуль.
Чтобы настроить этот модуль, выполните шаги ниже.
Добавьте имя библиотеки в переменную shared_preload_libraries в файле postgresql.conf.
shared_preload_libraries = 'online_analyze'
Включите этот модуль.
online_analyze.enable = on
Укажите минимальное число изменений строк, после которого может начаться немедленный анализ.
online_analyze.threshold = 50
Укажите процент от размера таблицы, при котором начнётся немедленный анализ.
online_analyze.scale_factor = 0.1
Выполняйте команду ANALYZE без VERBOSE.
online_analyze.verbose = off
Включите немедленный анализ для временных таблиц.
online_analyze.table_type = 'temporary'
Укажите минимальный интервал времени между вызовами ANALYZE для каждой таблицы, в миллисекундах.
online_analyze.min_interval = 10000
Расширение auto_dump предназначено для сбора данных по длительным и проблемным запросам и последующего воспроизведения этих запросов с целью устранения неполадок.
Чтобы включить и настроить это расширение, выполните следующие действия:
Добавьте auto_dump в параметр shared_preload_libraries в файле postgresql.conf.
shared_preload_libraries = 'auto_dump'
Включите расширение:
auto_dump.enable = on
Перед использованием расширения задайте другие обязательные параметры конфигурации и перезапустите сервер баз данных, чтобы изменения вступили в силу.