Оптимизация работы БСП на примере типового функционала работы с дополнительными отчетами и обработками

10.12.24

Задачи пользователя - Менеджеры внешних отчетов

За последние лет 5 несколько раз сталкиваюсь с проблемой на разных проектах (в конфигурациях 1С:ERP, 1С:ERP УХ и многих других, основанных на БСП), когда много пользователей (около 30 тысяч) в информационной базе, время добавления доступа для пользователей занимает значительное время. Открытие списка занимает от 10 до 15 секунд, и каждое изменение списка еще примерно столько же.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Ускорение работы БСП в части - Дополнительные отчеты и обработки
.cfe 11,48Kb
1
1 Скачать (1 SM) Купить за 1 850 руб.

 

Самое плохое, что выполняется не один неявный запрос к базе данных, а несколько десятков тысяч мелких запросов с получением данных из ссылки для сортировки. Запросы мелкие и выполняются быстро, которые сложно найти, так как часто даже при сборке ТЖ (технологический журнал) ставится отбор на время выполнения запроса. А если одновременно несколько сотрудников начинают активно добавлять пользователей, тогда мелкими запросами отнимали от ½ до 2/3 от общего количества запросов к базе данных, что тормозит выполнения всех запросов (сильно зависит от серверов и размера базы данных).

Шаг 1, попробуем заменить получение сортированного списка запросом, например,

Запрос = Новый Запрос("ВЫБРАТЬ Ссылка КАК Пользователь ИЗ Справочник.Пользователи ГДЕ Ссылка В (&Список) УПОРЯДОЧИТЬ ПО Наименование");

Запрос.УстановитьПараметр("Список", Приемник);

Приемник = Запрос.Выполнить().Выгрузить().ВыгрузитьКолонку("Пользователь");

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

Результат приятно удивил - вместо 12,93 сек стало 1,58 сек, что в 8 раз быстрее.

 

 

Шаг 2, аналогичное изменение применил и для открытия формы в процедуре «ЗаполнитьТаблицы», сортировку добавил на уровне запроса, а сортировку результата убрал, результат тоже хороший - с 11,88 сек время сократилось до 0,53, что быстрее в 22 раза.

Шаг 3, по идее на этом можно было и завершить, но при добавлении нескольких десятков пользователей по-прежнему занимает много времени. Самый простой и очевидный способ - отключить автоматическую сортировку списков, и это дает значительное ускорение до 0,0003 сек, что в 5267 раз быстрее, чем на шаге 2, и в 43100 раз быстрее, чем изначально.

 

 

Пример реализации, с отключением автоматической сортировки.

 

 

Итого получили следующие результаты:

 

Время

стандарт

оптимизация

дельта, раз

Открытие

(О)

Большой

(Б)

Маленький

(М)

О

Б

М

О

Б

М

автообновление

11,88

12,93

0,2

0,53

1,58

0,01

22

8

20

без обновления

11,88

12,93

0,2

0,53

0,0003

0,0013

22

43100

154

 

Улучшение есть на списке любого объема, даже на маленьком (5 пользователей). Но время 0,2 сек не заметно, но когда количество пользователей переваливает одну или две сотни, тогда время занимает около секунды на операциях открытия списка и изменении, что уже может вызывать проблемы. То есть если у вас более 100 пользователей в базе, и вы используете внешние обработки или отчеты на регулярной основе, есть смысл задуматься об этом улучшении.

Вместо вывода, проблемы бывают даже в самых неожиданных местах, и нет предела совершенству.

Проверено на следующих конфигурациях и релизах:

  • 1С:ERP Управление предприятием 2, релизы 2.5.18.41
  • 1С:Управление холдингом 3.2 (русский и английский интерфейсы), релизы 3.2.4.2

ERP УправлениеХолдингом БСП ДополнительныеОтчетыИОбработки

См. также

БСП (Библиотека стандартных подсистем) Программист Платные (руб)

Синтакс-помощник БСП - cправочник по библиотеке стандартных подсистем. В состав справочника входит описание экспортных процедур и функций, размещенных в областях кода ПрограммныйИнтерфейс БСП.

1800 руб.

21.11.2024    1159    3    12    

5

БСП (Библиотека стандартных подсистем) Программист Платформа 1С v8.3 Бесплатно (free)

В статье описан алгоритм для включения документа или справочника в систему БСП. Будет полезно программистам 1С, начинающим работать с БСП.

24.10.2024    1348    PROSTO-1C    0    

16

БСП (Библиотека стандартных подсистем) Работа с интерфейсом Программист Платформа 1С v8.3 Бесплатно (free)

В материале описан универсальный механизм работы с добавленными элементами на общую форму «ФормаОтчета». Думаю, облегчит работу многим разработчикам.

08.10.2024    1166    PROSTO-1C    4    

14

БСП (Библиотека стандартных подсистем) Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

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

04.10.2024    2041    MadRave    11    

24

БСП (Библиотека стандартных подсистем) Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример отслеживания прогресса фонового выполнения дополнительной обработки с использованием программного интерфейса длительных операций БСП.

10.09.2024    2130    MadRave    4    

18

БСП (Библиотека стандартных подсистем) Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Добавим дополнительные свойства в новый документ средствами БСП

02.09.2024    4325    John_d    10    

53

БСП (Библиотека стандартных подсистем) Программист Платформа 1С v8.3 Бесплатно (free)

Всё больше организаций выбирает для серверов под 1С операционные системы Linux. Одним из отличий систем Windows и Linux является отсутствие COM объектов, которые зачастую использовались для формирования печатных форм офисных документов (Word). Конечно, можно выполнять печать и на клиенте, но есть риск импортозамещения. В работе у меня случались проблемы с зависанием процесса Word, поэтому я не люблю его использовать.

29.07.2024    5711    PROSTO-1C    12    

52
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Iaskeliainen 392 10.12.24 18:47 Сейчас в теме
Для жадных расширение можно скачать бесплатно :-)
Прикрепленные файлы:
фикс_ДополнительныеОтчетыИОбработки.cfe
ru_hawk; user637193_azam.nuriev; +2 Ответить
2. ru_hawk 11.12.24 15:17 Сейчас в теме
Тоже замечал тормоза при работе со списом пользователей, однако жгучего желания исправить не возникло ввиду редекого использования. На будущее обязательно надо будет внедрить в нашу ERP УХ. Спасибо, Алексей!
Оставьте свое сообщение