Лучший инструмент 1С эксперта по технологическим вопросам это голова. Подготовка к 1С:Эксперту по технологическим вопросам. Основной курс©

Удар был нанесен тупым предметом, очевидно головой (из милицейского протокола) ©

Из тех кто не собирается стать тимлидом (а возможно и из них тоже) 1С-ники делятся на тех кто собирается идти на экзамен 1С:Эксперт по технологическим вопросам и те кто собирается идти еще раз на экзамен 1С:Эксперт по технологическим вопросам.
Тем из них, кто в очередной раз поклялся за лето/отпуск переделать домашки курса

 

и не только им поможет данная утилита.

Внимание! Все действия нужно производить осознанно и понимая их последствия, особенно на рабочих базах.

Программа предоставляется бесплатно по принципу "AS IS" / "Как есть".

Автор гарантирует, что никаких действий, кроме указанных в описании, приложение не производит, но не несёт ответственности за ваши данные. 

Постановка задачи

Позволю себе привести цитату:

...хочу поднять тему, которая представляет собой одну большую боль для администраторов, разработчиков и тестировщиков высоконагруженных (и не очень) систем под управлением PostgreSQL. Даже не «боль», а «БОЛЬ»!

Удивительно, что за почти 30 лет существования PostgreSQL не появилось нормальных инструментов для получения вменяемых счетчиков и трассировок. Все, кто работают с MS SQL Server используют профайлер. Это обязательный и привычный инструмент, который позволяет вылавливать запросы, интересные нам в рамках исследования.

Виктор Богачев тоже на курсе (кто еще не проходил, обязательно) хвалит PostgreSQL (и отдельно компанию Postgres Professional, им еще раз большое спасибо и от меня. Такой на мой взгляд и должна быть ИТ компания), но все примеры показывает в Microsoft SQL Server Profiler.

Видимо потому, что хотя импортозамещение уже столько лет шагает по стране, но фирма 1С идет быстрее.
Замолвлю слово о бедном гусаре о пользователях linux и предложу графическое и понятное решение.

Те кто не любит много букв, смотрят видео

Решение

Графическое приложение на базе PyQt6, которое позволяет легко настраивать сбор планов запросов как средствами PostgreSQL, так и технологическим журналом 1С Предприятие с их последующей визуализацией на специализированных сайтах по выбору.

Выполняется как обычная программа по двойному щелчку мыши.

Не требует прав администратора для визуализации, и требующее их для настройки логов.

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

Также предусмотрена выгрузка шаблона файла logcfg.xml для включения файла технологического журнала 1С Предприятие для сбора планов запросов PostgreSQL.

Предполагаемый режим работы с программой.

Вы задаете минимальное время выполнения запросов, в разумных пределах и ориентируясь на длительность вашего запроса в 1С.

По кнопке "Включить" в конец файла postgresql.conf будут добавлены настройки для сбора планов запросов.

Скрытый текст

shared_preload_libraries = 'auto_explain'
auto_explain.log_min_duration = {min_duration}      # For learning
auto_explain.log_format = 'json'        # JSON format
auto_explain.log_analyze = on           # Real time figures
auto_explain.log_buffers = on           # Memory usage
auto_explain.log_timing = on            # Important for visualizers
auto_explain.log_verbose = on           # Maximum details
auto_explain.log_nested_statements = on  # Plans inside functions/triggers

По кнопке "Выключить" эти настройки будут удалены из файла postgresql.conf 

На linux вы можете настроить сбор планов запросов в отдельный файл

Скрытый текст

Совет от gemini
Перенаправление в Syslog
Чтобы отделить эти сообщения от остальных, мы заставим Postgres отправлять логи в системный журнал с определенным «идентификатором» (facility).

В том же postgresql.conf:

Ini, TOML log_destination = ‘syslog’ syslog_facility = ‘LOCAL1’ syslog_ident = ‘postgres_plans’ 3. Настройка фильтрации (rsyslog) Теперь нужно сказать операционной системе: «Всё, что приходит от LOCAL1, клади в отдельный файл».

Создайте файл конфигурации для rsyslog (например, /etc/rsyslog.d/60-postgres-plans.conf):

Bash if $programname == ‘postgres_plans’ then /var/log/postgresql/query_plans.log & stop Инструкция & stop важна — она говорит системе не дублировать эти записи в общий файл /var/log/syslog или messages.

Затем перезапустите службы:

Bash sudo systemctl restart rsyslog sudo systemctl restart postgresql

По кнопке "Перезапустить postgresql" сервер будет перезапущен, заполнится поле "Файл сбора логов" для выбора лог файла новым значением и начнется сбор логов с данными запросов.

По нажатию кнопки "Начать отслеживание" программа будет мониторить изменения в файле из поля "Файл сбора логов" с заданной периодичностью и выводить найденные запросы в таблицу.

Выбрав строку с интересующим вас запросом вы можете его отправить напрямую на сайт для визуализации или в буфер обмена если например сайт у вас уже открыт.

На мой вкус лучший визуализатор для новичков это tatiyants.com, он настолько старый, что принимает планы только из буфера обмена, остальные по API.

При отсутствии прав вы можете только анализировать файл с уже собранными планами запросов выбрав его в поле "Файл сбора логов" и нажав кнопку "Начать отслеживание"

Рекомендации:

Начните со знакомых всем рекомендаций
Методические материалы для разработчиков и администраторов 1С 1С:Предприятие 8. -> Система стандартов и методик разработки конфигураций -> Реализация обработки данных -> Оптимизация запросов -> Эффективные условия запросов

Вы удивитесь насколько поумнел планировщик PostgreSQL.

В частности классический пример

Скрытый текст

2. Оператор ИЛИ

2.1. В основном условии оператор ИЛИ можно использовать только для последнего из используемых или единственного поля индекса, когда оператор ИЛИ можно заменить на оператор В.

ПРАВИЛЬНО:

ГДЕ     Таблица.Поле = &Значение1     ИЛИ Таблица.Поле = &Значение2

т.к. можно переписать при помощи оператора В (специально переписывать не нужно, можно оставить, как есть):

ГДЕ     Таблица.Поле В (&Значения)

НЕПРАВИЛЬНО:

ГДЕ     Таблица.Поле1 = &Значение1     ИЛИ Таблица.Поле2 = &Значение2

нельзя переписать при помощи "В", но можно переписать при помощи "ОБЪЕДИНИТЬ ВСЕ" (каждое поле Поле1 и Поле2 должны быть проиндексированы):

ГДЕ     Таблица.Поле1 = &Значение1

ОБЪЕДИНИТЬ ВСЕ

ГДЕ     Таблица.Поле2 = &Значение1

планировщик PostgreSQL сам берет и приводит к объединению и запрос 
ВЫБРАТЬ     Товары.Ссылка КАК Ссылка ИЗ     Справочник.Товары КАК Товары ГДЕ     (Товары.Наименование = &Наименование             ИЛИ Товары.Код = &Код ИЛИ Товары.Артикул = &Артикул)

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

Но это уже тема другой публикации

Благодарности:

Бесплатным тарифам от всех ai агентов известных индусам.

Неожиданно в этот раздел попадают господа из компании DockerHosting, которые предложили мне хостинг запросто так, даже без публикации статей в из блоге.
Правда пока не дали.

Но благодаря этому аттракциону невиданной щедрости утилита будет бесплатной.
Попробую вариант с донатами, хотя слабо в него верю.

Файлы можно взять на github.
Под windows выложу позже. Не издеваюсь, просто так получилось, надо еще потестировать.
Кода нет, но жителей Хабра это никогда не останавливало, они могут не только исходники вытащить из программы, но и прислать обратно с исправлениями.

Желающие поддержать автора переходят по ссылке "На вайбкодинг", а то надоело быть для нейросетей нидерландским казахом проживающим в Стокгольме.

Желающие поддержки знают, где меня искать, время за пределами рабочего. Там же будут описания как получить доступ к бесплатным вариантам вайбкодинга на топовых моделях, которые постят в соцсети в основном индусы.

Спонсор этого выпуска как обычно питерская погода.

Пользуясь случаем поздравляю наш город с Днем Рождения!

а также приглашаю на бесплатный Книжный салон 2026 на Дворцовой

не пожалеете.

Статья продолжает серию публикаций:

Серия «Рецепты от Капитана» на всякий случай