Оптимизация проведения документов по регистрам

20.09.11

База данных - HighLoad оптимизация

Оптимизация проведения документа по регистрам. Увеличение производительности перепроведения базы в 2-3 раза.

Скачать файл

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

Наименование По подписке [?] Купить один файл
пример использования механизма (1 документ)
.dt 251,73Kb
57
57 Скачать (1 SM) Купить за 1 850 руб.

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

Данный механизм используется на рабочей базе. Производительность проведения некоторых документов увеличена в 3 раза

 

См. также

HighLoad оптимизация Программист Платформа 1С v8.3 Бесплатно (free)

Метод очень медленно работает, когда параметр приемник содержит намного меньше свойств, чем источник.

06.06.2024    9260    Evg-Lylyk    61    

44

HighLoad оптимизация Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Анализ простого плана запроса. Оптимизация нагрузки на ЦП сервера СУБД используя типовые индексы.

13.03.2024    5097    spyke    28    

49

HighLoad оптимизация Программист Платформа 1С v8.3 Бесплатно (free)

Оказывается, в типовых конфигурациях 1С есть, что улучшить!

13.03.2024    7573    vasilev2015    20    

42

HighLoad оптимизация Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Обработка для простого и удобного анализа настроек, нагрузки и проблем с SQL сервером с упором на использование оного для 1С. Анализ текущих запросов на sql, ожиданий, конвертация запроса в 1С и рекомендации, где может тормозить.

2 стартмани

15.02.2024    12422    241    ZAOSTG    80    

115

HighLoad оптимизация Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Принимать, хранить и анализировать показания счетчиков (метрики) в базе 1С? Почему бы нет? Но это решение быстро привело к проблемам с производительностью при попытках построить какую-то более-менее сложную аналитику. Переход на PostgresSQL только временно решил проблему, т.к. количество записей уже исчислялось десятками миллионов и что-то сложное вычислить на таких объемах за разумное время становилось все сложнее. Кое-что уже практически невозможно. А что будет с производительностью через пару лет - представить страшно. Надо что-то предпринимать! В этой статье поделюсь своим первым опытом применения СУБД Clickhouse от Яндекс. Как работает, что может, как на нее планирую (если планирую) переходить, сравнение скорости работы, оценка производительности через пару лет, пример работы из 1С. Все это приправлено текстами запросов, кодом, алгоритмами выполненных действий и преподнесено вам для ознакомления в этой статье.

1 стартмани

24.01.2024    5669    glassman    18    

40

HighLoad оптимизация Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Встал вопрос: как быстро удалить строки из ТЗ? Рассмотрел пять вариантов реализации этой задачи. Сравнил их друг с другом на разных объёмах данных с разным процентом удаляемых строк. Также сравнил с выгрузкой с отбором по структуре.

09.01.2024    14018    doom2good    49    

71
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. noprogrammer 239 20.09.11 14:31 Сейчас в теме
не совсем понятно в чем выигрыш.... неужели "записать" уже подготовленные движения дольше чем:
1.Прочитать все движения до проведения
2.сравнить все движения фактически после проведения (с тем что было)
?
2. alexk-is 6544 20.09.11 14:44 Сейчас в теме
(1) Это как раз просто.
Если в движениях нет разницы, то их можно не записывать. Соответственно ""записать" уже подготовленные движения" дольше чем их не записывать совсем. :)
3. noprogrammer 239 20.09.11 14:48 Сейчас в теме
(2)
Если в движениях нет разницы, то их можно не записывать. Соответственно ""записать" уже подготовленные движения" дольше чем их не записывать совсем. :)


Время затраченное на чтение движений "до", сравнение движений "после" как мне кажется большее чем время на "запись" уже готовых движений.
+ не совсем понятно, что происходит с "удалением движений" перед проведением (такое ощущение, что они вообще не трогаются)
4. sebe 100 20.09.11 14:57 Сейчас в теме
(3) время на запись больше чем время сравнения (опытным путем). "Удаление движения" это при отмене проведения.
5. sebe 100 20.09.11 15:00 Сейчас в теме
(3) если логически подумать то на жесткий диск запись идет медленее чем чтение, а расчет сравнения двух таблиц вообще почти моментально по сравнению с записью и чтением.
6. alexk-is 6544 20.09.11 15:03 Сейчас в теме
(3) Можно выделить 3 режима проведения документов:
1. Проведение новых
2. Проведение проведенных без внесения изменений
3. Проведение измененных проведенных документов

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

При массовом проведении документов большинство из них попадают в категорию "проведение проведенных без внесения изменений". Отсюда и ускорение
7. sebe 100 20.09.11 15:08 Сейчас в теме
(6) так и есть что при перепроведении месяца производительность увеличивается в 2-3 раза, т.к. основная масса документов не меняет движений.
8. hogik 443 20.09.11 16:21 Сейчас в теме
(0)
Идея очевидная. Странно, что в "штатных" средствах делается иначе. ;-)
По моему опыту работы с различными ИС - только в продуктах 1С делается "тупое" обновления не измененных данных без предварительного анализа.
9. sebe 100 20.09.11 16:35 Сейчас в теме
(8) Былобы хорошо чтоб сама платформа делала такую проверку. может когда нибудь реализуют.
10. pumbaE 20.09.11 16:55 Сейчас в теме
(8) даже хуже, если посмотреть как делают расчет зарплатных документов... (любой расчет очищает движения, делает заново рассчитывает и все ... отказаться от нового расчета невозможно).
11. anig99 2852 20.09.11 22:46 Сейчас в теме
(0) (9)
http://www.sibeaz.ru/ver8111.shtml
Прочее
Ускорено перепроведение документов, выполняющих движения по регистру бухгалтерии, в тех случаях, когда не используется автоматическое удаление движений и не изменяются движения документа. Теперь, если новый набор записей совпадает со старым набором записей, сохраненным в базе данных, перезапись набора записей регистра бухгалтерии в базе данных не происходит.

Где в следующих редакциях распространили на другие регистры.

В 8.2 появилась возможность самому устанавливать режим записи.

В принципе, не работает, если предварительно очищать и записывать движения.

Так что пока "-" за незнание мат.части. Даже, если Ваше решение лучше поведения платформы при ПРАВИЛЬНОЙ работе с движениями в режиме проверки модифицированности, то не раскрыто почему это так или почему это не работает в типовых или у Вас до оптимизации.
Хотя посмотрев код не вижу чего-то нового, кроме лишней процедуры на доп.проверку модифицированности. По-моему достаточно просто не очищать движения перед записью и платформа сама сравнит движения.

Покажите код записи движений ДО Вашей оптимизации. Что-то было не так, если механизм платформы не работал.
Прикрепленные файлы:
pumbaE; Evg-Lylyk; Borisych; +3 Ответить
12. aspirator23 339 21.09.11 22:02 Сейчас в теме
1с опубликовала год, а то и два назад технологию проведения документов как они это называют "по-новому". Описано в нескольких книжках и даже на сайте 1с в открытой части. Общее описание этих правил не бог весть какое сложное, но там более комплексно рассмотрено "правильное" проведение документов.
Подразумевается перевод полностью или частично на управляемое проведение. То что описано в данной публикации - это только часть этой технологии. Не в обиду автору публикации.
13. dkprim 5 22.09.11 14:31 Сейчас в теме
не смотря на все минусы, озвученные здесь - публикация полезная. спасибо :)
14. almas 258 23.09.11 09:08 Сейчас в теме
Спасибо, поднял интересную тему.
15. RustIG 1747 28.10.11 03:03 Сейчас в теме
(0) просим код вместо картинки и двух предложений в студию ! :)
я полагаю, пока 1С развивает эту тему в 8.2
ты эту тему развернешь на 8.1 :)
Оставьте свое сообщение