[Замер] Кто самый быстрый в конфигураторе?

28.03.24

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

Сравним «Регистры сведений» с «Сервисами интеграции» и узнаем, кто быстрее!

Скачать файл

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

Наименование Бесплатно
zamer.cf
.cf 104,43Kb ver:1.0.0
18
18 Скачать бесплатно

Для тех, кто не понимает, как можно сравнивать «Коннектор для 1С:Шины» и «Регистры сведений», лучше для начала прочитать вот эти две статьи:

Поинтегрируем: сервисы интеграции – новый стандарт или просто коннектор?

Сервисы интеграции без Шины и интеграции

 

После того, как я написал статьи про «Сервисы интеграции» и опубликовал инструменты по работе с ними, хотел двигаться дальше по плану, но коллеги стали задавать вопросы. Один из вопросов не смог оставить без внимания, так как самому стало интересно узнать на него ответ:

 

 

Спасибо за вопрос Cmapnep.

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

 

Приступим

Для начала создаем чистую как слезу младенца конфигурацию. Добавляем в нее «Сервис интеграции» с именем «ДляЗамера» и создадим канал «СообщенияДляЗамера» на отправку:

 

 

Это будет подопытный №1.

 

Далее создаем «Регистр сведений» с именем «СообщенияДляЗамера» и максимально повторяем структуру канала и «сообщения сервисов интеграции»:

 

 

Где:

           Измерения:

                     Идентификатор – УникальныйИдентификатор

           Ресурсы:

Позиция – Число(10)

ДатаУстаревания – Дата и время

ШапкаСообщения – ХранилищеЗначения – тут мы будем хранить структуру свойств и параметров.

ТелоСообщения – ХранилищеЗначения – тут мы будем хранить тело сообщения

Это будет подопытный №2.

 

Давайте посмотрим, что у нас получилось в СУБД

По-моему, вышло неплохо, даже Борис Георгиевич не отличит:

 

 

Где:

           InfoRg53 – Регистр сведений «СообщенияДляЗамера»

           IntegChannelOutQueue50 – Канал «СообщенияДляЗамера»

 

Добавим обработки в нашу конфигурацию.

Нам понадобится обработка «Сообщения сервисов интеграции» и создадим обработку, с помощью которой будем запускать замеры «Замер регистров сведений и сервисов интеграции»:

 

 

 
 Код обработки:
&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
	
	ЧислоПотоков = 1;
	КоличествоЗаписей = 1;
	ТипЗамера = Элементы.ТипЗамера.СписокВыбора[0].Значение; 
	ТекущийРазмерТела = 0;
	
КонецПроцедуры

&НаКлиенте
Процедура ТелоСообщенияПриИзменении(Элемент)
	ТекущийРазмерТела = ТелоСообщенияПриИзмененииНаСервере(ТелоСообщения);
КонецПроцедуры       

&НаСервереБезКонтекста
Функция ТелоСообщенияПриИзмененииНаСервере(ТелоСообщения)
	
	Буфер = ПолучитьБуферДвоичныхДанныхИзСтроки(ТелоСообщения); 
	//Получает размер двоичных данных в байтах.
	Возврат Буфер.Размер;

КонецФункции

&НаКлиенте
Процедура НачатьЗамер(Команда)
	НачатьЗамерНаСервере();
КонецПроцедуры

&НаСервере
Процедура НачатьЗамерНаСервере()
	
	Если ЧислоПотоков < 1 Тогда 
		ЧислоПотоков = 1;
	КонецЕсли;
	
	Если КоличествоЗаписей < 1 Тогда 
		КоличествоЗаписей = 1;
	КонецЕсли;
		
	СтруктураВходныхПараметров = Новый Структура;
	СтруктураВходныхПараметров.Вставить("ДатаУстаревания", 	ТекущаяДатаСеанса() + 60 * 86400);  
	СтруктураВходныхПараметров.Вставить("КодОтправителя", 	"ЗамерРегистровСведенийИСервисовИнтеграции"); 
	СтруктураВходныхПараметров.Вставить("ТелоСообщения", 	ТелоСообщения);
	СтруктураВходныхПараметров.Вставить("РазмерСообщения", 	ТекущийРазмерТела);
	СтруктураВходныхПараметров.Вставить("ТипСообщения", 	ТипЗамера);
	
	
	// объем порции данных для обработки каждым потоком
	РазмерПорции = Цел(КоличествоЗаписей / ЧислоПотоков);
	
	Для НомерПотока = 1 По ЧислоПотоков Цикл
		
		СтруктураВходныхПараметров.Вставить("КодПолучателя", ТипЗамера+"_Поток"+НомерПотока); 
				
		Если НомерПотока = ЧислоПотоков Тогда
			// если это последний поток, то посылаем все оставшиеся данные
			РазмерПорции = КоличествоЗаписей - (ЧислоПотоков * РазмерПорции) + РазмерПорции;
		КонецЕсли; 
		
		СтруктураВходныхПараметров.Вставить("КоличествоЗаписей", РазмерПорции);

		// определяем массив параметров для процедуры
		НаборПараметров = Новый Массив;
		НаборПараметров.Добавить(СтруктураВходныхПараметров);
		
		ФоновыеЗадания.Выполнить("ФоновоеВыполнение.ЗаписатьСообщения"+ТипЗамера, НаборПараметров);

	КонецЦикла;
	

КонецПроцедуры

Примечание:

           У нас будет три типа замера.

           1 Сервис интеграции – запись в канал сервиса интеграции

2 РС набор записей – запись в регистр сведений при помощи набора данных.

3 РС менеджер записи – запись в регистр сведений при помощи менеджера записи.

 

Еще нам понадобится хранилище результатов для замеров. Вообще логично было создать регистр сведений, но я решил сделать «сервис интеграции» и для замеров. Это просто моя прихоть, не больше того 😉

 

 

 

Остается создать модуль, для фоновых заданий, в котором будут проходить сами замеры.

Назовем модуль «ФоновоеВыполнение»:

 

 

 
 Код модуля:
// Процедура - Записать сообщения в регистр сведений при помощи Менеджера записи
//
// Параметры:
//  СтруктураВходныхПараметров	 - Структура - Содержится вся необходимая для замера информация 
//
Процедура ЗаписатьСообщенияРСМенеджерЗаписи(СтруктураВходныхПараметров) Экспорт
	
	ВремяНачала = ТекущаяУниверсальнаяДатаВМиллисекундах();

	КоличествоЗаписей = СтруктураВходныхПараметров.КоличествоЗаписей;	
	Для счетчик = 1 По КоличествоЗаписей Цикл
		
		// Так же как и в сообщениях сервисов интеграции считаем УИ уникальным
		ТекИдентификатор = Новый УникальныйИдентификатор;	
		МенеджерЗаписи  = РегистрыСведений.СообщенияДляЗамера.СоздатьМенеджерЗаписи();			
		
		// Записываем тело сообщения
		МенеджерЗаписи.ТелоСообщения = Новый ХранилищеЗначения(СтруктураВходныхПараметров.ТелоСообщения);  
		
		// Изображаем структуру на подобии Сообщения сервисов интеграции
		МенеджерЗаписи.Идентификатор	= ТекИдентификатор;     		
		МенеджерЗаписи.ДатаУстаревания	= СтруктураВходныхПараметров.ДатаУстаревания; 
		МенеджерЗаписи.Позиция		= счетчик;
		
		// Заполняем свойства сообщения
		ШапкаСообщения = Новый Структура; 
		ШапкаСообщения.Вставить("ДатаОтправки", 	ТекущаяДатаСеанса());  
		ШапкаСообщения.Вставить("ДатаУстаревания", 	СтруктураВходныхПараметров.ДатаУстаревания);
		ШапкаСообщения.Вставить("Идентификатор", 	ТекИдентификатор); 
		ШапкаСообщения.Вставить("КодОтправителя", 	СтруктураВходныхПараметров.КодОтправителя);
		ШапкаСообщения.Вставить("КодПолучателя", 	СтруктураВходныхПараметров.КодПолучателя); 
		
		// Заполняем свойство Параметры сообщения
		Параметры = Новый Структура("ТипСообщения", СтруктураВходныхПараметров.ТипСообщения);
		Параметры.Вставить("РазмерСообщения", 		СтруктураВходныхПараметров.РазмерСообщения);
		ШапкаСообщения.Вставить("Параметры", Параметры);  
		
		// Помещаем структуру свойств
		МенеджерЗаписи.ШапкаСообщения = Новый ХранилищеЗначения(ШапкаСообщения);	
		
		// Сохраняем сообщение в регистре
		МенеджерЗаписи.Записать(); 
	
	КонецЦикла;
	
	Длительность = ТекущаяУниверсальнаяДатаВМиллисекундах() - ВремяНачала; 
	СоздатьСообщениеОЗамере(СтруктураВходныхПараметров, Длительность);
	
КонецПроцедуры

// Процедура - Записать сообщения в регистр сведений при помощи Набора записи
//
// Параметры:
//  СтруктураВходныхПараметров	 - Структура - Содержится вся необходимая для замера информация 
//
Процедура ЗаписатьСообщенияРСНаборЗаписей(СтруктураВходныхПараметров) Экспорт
	
	ВремяНачала = ТекущаяУниверсальнаяДатаВМиллисекундах();
	
	КоличествоЗаписей = СтруктураВходныхПараметров.КоличествоЗаписей;	
	Для счетчик = 1 По КоличествоЗаписей Цикл
		
		// Так же как и в сообщениях сервисов интеграции считаем УИ уникальным
		ТекИдентификатор = Новый УникальныйИдентификатор;
		НаборЗаписей = РегистрыСведений.СообщенияДляЗамера.СоздатьНаборЗаписей();  
		НаборЗаписей.Отбор.Идентификатор.Установить(ТекИдентификатор);
		
		НоваяЗапись  = НаборЗаписей.Добавить();	   
		// Записываем тело сообщения
		НоваяЗапись.ТелоСообщения = Новый ХранилищеЗначения(СтруктураВходныхПараметров.ТелоСообщения);
		
		// Изображаем структуру на подобии Сообщения сервисов интеграции
		НоваяЗапись.Идентификатор	= ТекИдентификатор;
		НоваяЗапись.ДатаУстаревания	= СтруктураВходныхПараметров.ДатаУстаревания; 
		НоваяЗапись.Позиция		= счетчик;   
		
		// Заполняем свойства сообщения
		ШапкаСообщения = Новый Структура; 
		ШапкаСообщения.Вставить("ДатаОтправки", 	ТекущаяДатаСеанса());  
		ШапкаСообщения.Вставить("ДатаУстаревания", 	СтруктураВходныхПараметров.ДатаУстаревания);
		ШапкаСообщения.Вставить("Идентификатор", 	ТекИдентификатор); 
		ШапкаСообщения.Вставить("КодОтправителя", 	СтруктураВходныхПараметров.КодОтправителя);
		ШапкаСообщения.Вставить("КодПолучателя", 	СтруктураВходныхПараметров.КодПолучателя); 
		
		// Заполняем свойство Параметры сообщения
		Параметры = Новый Структура("ТипСообщения", СтруктураВходныхПараметров.ТипСообщения);
		Параметры.Вставить("РазмерСообщения", 		СтруктураВходныхПараметров.РазмерСообщения);	
		ШапкаСообщения.Вставить("Параметры", Параметры);  
		
		// Помещаем структуру свойств
		НоваяЗапись.ШапкаСообщения = Новый ХранилищеЗначения(ШапкаСообщения);	
		
		// Сохраняем сообщение в регистре
		НаборЗаписей.Записать();   
		
	КонецЦикла;
	
	Длительность = ТекущаяУниверсальнаяДатаВМиллисекундах() - ВремяНачала; 
	СоздатьСообщениеОЗамере(СтруктураВходныхПараметров, Длительность);
	
КонецПроцедуры

// Процедура - Записать сообщения в регистр сведений при помощи Сообщения сервисов интеграции
//
// Параметры:
//  СтруктураВходныхПараметров	 - Структура - Содержится вся необходимая для замера информация 
//
Процедура ЗаписатьСообщенияСервисИнтеграции(СтруктураВходныхПараметров) Экспорт
	
	ВремяНачала = ТекущаяУниверсальнаяДатаВМиллисекундах(); 
	
	КоличествоЗаписей = СтруктураВходныхПараметров.КоличествоЗаписей;  	
	Для счетчик = 1 По КоличествоЗаписей Цикл 
		НовоеСообщение = СервисыИнтеграции.ДляЗамера.СоздатьСообщение(СтруктураВходныхПараметров.ДатаУстаревания);
		
		// Записываем тело сообщения
		Буфер = ПолучитьБуферДвоичныхДанныхИзСтроки(СтруктураВходныхПараметров.ТелоСообщения);   
		Тело = НовоеСообщение.ПолучитьТелоКакПоток();
		Тело.Записать(Буфер, 0, Буфер.Размер);
		Тело.Закрыть();
		
		// Заполняем свойства сообщения
		НовоеСообщение.КодОтправителя = СтруктураВходныхПараметров.КодОтправителя;
		НовоеСообщение.КодПолучателя = СтруктураВходныхПараметров.КодПолучателя;
		
		// Заполняем свойство Параметры сообщения
		НовоеСообщение.Параметры.Вставить("ТипСообщения", СтруктураВходныхПараметров.ТипСообщения);
		НовоеСообщение.Параметры.Вставить("РазмерСообщения", Буфер.Размер); 	
		
		// Сохраняем сообщение в канале
		СервисыИнтеграции.ДляЗамера.СообщенияДляЗамера.ОтправитьСообщение(НовоеСообщение);
		
	КонецЦикла;
	
	Длительность = ТекущаяУниверсальнаяДатаВМиллисекундах() - ВремяНачала; 
	СоздатьСообщениеОЗамере(СтруктураВходныхПараметров, Длительность);
	
КонецПроцедуры	         

// Процедура - Создать сообщение о замере
//
// Параметры:
//  СтруктураВходныхПараметров	 - Структура - Содержится вся необходимая для замера информация
//  Длительность				 - Число	 - Результат замера в миллисекундах
//
Процедура СоздатьСообщениеОЗамере(СтруктураВходныхПараметров, Длительность) 
	
	НовоеСообщение = СервисыИнтеграции.СлужебноеХранилище.СоздатьСообщение(СтруктураВходныхПараметров.ДатаУстаревания);	
	
	Буфер = ПолучитьБуферДвоичныхДанныхИзСтроки(СтруктураВходныхПараметров.ТелоСообщения);   
	Тело = НовоеСообщение.ПолучитьТелоКакПоток();
	Тело.Записать(Буфер, 0, Буфер.Размер);
	Тело.Закрыть();
	
	НовоеСообщение.КодОтправителя = СтруктураВходныхПараметров.КодОтправителя;
	НовоеСообщение.КодПолучателя = СтруктураВходныхПараметров.КодПолучателя;

	НовоеСообщение.Параметры.Вставить("ТипСообщения", 	СтруктураВходныхПараметров.ТипСообщения);
 	НовоеСообщение.Параметры.Вставить("Длительность", 	Длительность);	
	НовоеСообщение.Параметры.Вставить("РазмерСообщения",Буфер.Размер);
	
	СервисыИнтеграции.СлужебноеХранилище.РезультатыЗамеров.ОтправитьСообщение(НовоеСообщение);

КонецПроцедуры

 

 

Создаем подсистему «Замеры», добавляем в ее состав все созданные ранее объекты:

 

 

Заходим в клиента и активируем «сервисы интеграции» без настроек.

Я буду использовать обработку «Настройка сервисов интеграции»:

 

 

Перед замерами я проверил, что во всех трех случаях операции записи занимают примерно один и тот же процент времени от выполнения кода замера.

1 Сервисы интеграции сохраняют сообщение так:

СервисыИнтеграции.ДляЗамера.СообщенияДляЗамера.ОтправитьСообщение(НовоеСообщение);

Эта операция заняла 86,24% от всего времени при замере.

 

 

           2 Запись в регистр сведений через менеджер записи:

МенеджерЗаписи.Записать();

Эта операция заняла 85,70% от всего времени при замере.

 

 

3 Запись в регистр сведений через набор записи:

НаборЗаписей.Записать();

Эта операция заняла 86% от всего времени при замере.

 

 

Как видите, все операции записи данных занимают примерно равный процент выполнения всего кода.

 

Начинаем замерять

*Все данные в таблицах будут выведены в миллисекундах.

*Каждый замер будет проводиться три раза. Среднее из трех замеров будем считать за результат

*Будем создавать по 10000 сообщений на каждый замер

*Будем делать замеры в один, два и четыре потока

*Будем делать замеры без тела, с телом 1 кб и телом 10кб

 

Замер с пустым телом сообщения в один поток:

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Сервис интеграции

40079

43599

44401

42693

1

РС набор записей

54049

55376

48210

52545

3

РС менеджер записи

48878

49086

56296

51420

2

 

 

Сервисы интеграции показали себя лучше регистров, запись прошла примерно на 17-19% быстрее.

 

Замер с пустым телом сообщения в два потока:

 

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Поток1

Поток2

Поток1

Поток2

Поток1

Поток2

Сервис интеграции

22524

22515

22614

22606

22232

22222

22452

1

РС набор записей

28926

28925

28401

28418

26940

26931

28090

2

РС менеджер записи

28921

28939

27777

27783

29184

29178

28630

3

 

 

В два потока получили сильный прирост по записи, примерно в 2 раза быстрее, чем в один поток. Сервисы интеграции показали себя быстрее регистров примерно на 20-22%.

 

Замер с пустым телом сообщения в четыре потока:

 

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Птк1

Птк2

Птк3

Птк4

Птк1

Птк2

Птк3

Птк4

Птк1

Птк2

Птк3

Птк4

Сервис интеграции

13414

13453

13453

13462

12771

12782

12797

12823

13077

13032

13076

13150

13108

1

РС набор записей

15915

15951

15957

15918

15935

15958

15953

15958

15506

15433

15453

15453

15783

3

РС менеджер записи

15745

15782

15814

15820

15095

15100

15108

15198

15294

15373

15385

15280

15416

2

 

 

В четыре потока получили сильный прирост по записи, более чем в 3 раза быстрее, чем в один поток, сервисы интеграции показали себя быстрее регистров примерно на 15-17%.

 

Замер с телом содержащим сообщение 1024 байт в один поток:

 

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Сервис интеграции

42337

41789

41862

41996

1

РС набор записей

52045

54855

49505

52135

3

РС менеджер записи

53777

50024

52400

52067

2

 

 

Сервисы интеграции показали себя лучше регистров, запись прошла примерно на 19% быстрее. Я сравнил в SQL тело сообщения у регистров и сообщения сервисов интеграций, они практически совпали за исключением трех небольших фрагментов.

 

Замер с телом, содержащим сообщение 1024 байт в два потока:

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Поток1

Поток2

Поток1

Поток2

Поток1

Поток2

Сервис интеграции

24934

24939

23742

23742

23752

23764

24146

1

РС набор записей

28960

28977

29067

29090

32072

32081

30041

3

РС менеджер записи

28900

28912

29572

29572

27370

27383

28618

2

 

 

Сервисы интеграции показали себя лучше регистров, запись прошла примерно на 16-20% быстрее.

 

Замер с телом, содержащим сообщение 1024 байт в четыре потока:

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Птк1

Птк2

Птк3

Птк4

Птк1

Птк2

Птк3

Птк4

Птк1

Птк2

Птк3

Птк4

Сервис интеграции

13672

13692

13714

13718

12651

12680

12813

12873

12603

12624

12653

12732

13035

1

РС набор записей

14618

14704

14717

14749

15533

15554

15567

15637

15160

15183

15225

15270

15160

2

РС менеджер записи

15748

15762

15762

15845

16305

16310

16347

16353

15406

15438

15516

15518

15859

3

 

 

В четыре потока получили сильный прирост по записи, более чем в 3 раза быстрее, чем в один поток, сервисы интеграции показали себя быстрее регистров примерно на 14-18%.

 

Замер с телом, содержащим сообщение 10240 байт в один поток:

 

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Сервис интеграции

47235

46038

46477

46583

1

РС набор записей

52156

53904

49940

52000

2

РС менеджер записи

51683

56499

57946

55376

3

 

 

Сервисы интеграции показали себя лучше регистров, запись прошла примерно на 11-16% быстрее. По сравнению с телом 1024 байт сообщения сохранялись примерно на 10% дольше.

 

Замер с телом, содержащим сообщение 10240 байт в два потока:

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Поток1

Поток2

Поток1

Поток2

Поток1

Поток2

Сервис интеграции

25421

25453

25020

25027

28363

28370

26276

1

РС набор записей

28780

28801

30554

30584

34809

34815

31391

3

РС менеджер записи

29048

29050

29101

29114

29925

29923

29360

2

 

 

Сервисы интеграции показали себя лучше регистров, запись прошла примерно на 11-16% быстрее.

 

Замер с телом, содержащим сообщение 1024 байт в четыре потока:

 

 

Замер 1

Замер 2

Замер 3

Среднее

Место

Птк1

Птк2

Птк3

Птк4

Птк1

Птк2

Птк3

Птк4

Птк1

Птк2

Птк3

Птк4

Сервис интеграции

15300

15435

15505

15555

14176

14200

14190

14191

13660

13661

13696

13707

14440

1

РС набор записей

16128

16167

16160

16170

16058

16085

16072

16082

16284

16291

16297

16296

16174

3

РС менеджер записи

15899

15947

15960

16028

15677

15702

15703

15709

15555

15563

15577

15578

15742

2

 

 

В четыре потока получили сильный прирост по записи, более чем в 3 раза быстрее, чем в один поток, сервисы интеграции показали себя быстрее регистров примерно на 8-11%.

 

Итоги

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

Если вы до сих пор его не использовали, присмотритесь к нему.

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

 

Демонстрация замера:

 

 

На этом статью завершаю.

Всем желаю профессионального роста и интересных задач!

 

Полезные ссылки:

Три инструмента для сервисов интеграции – Бесплатные инструменты по работе с сервисами интеграции.

PAPI-tools – Проект на GitHub содержащий исходники обработок, которые будут первоначально выкладываться в данном проекте, а в будущем перетекать в подсистему PAPI (релиз подсистемы запланирован на 19.05.2024)

Поинтегрируем: сервисы интеграции – новый стандарт или просто коннектор? – Статья описывает механизм «Сервисы интеграции» изнутри и снаружи

Сервисы интеграции без Шины и интеграции – Статья показывает пример по использованию сервисов интеграции и сообщений сервисов интеграции с «ПоказатьОповещениеПользователя»

замер сервис интеграции канал вопрос сообщения сервисов интеграции регистр сведений сообщения тело сообщения набор записей менеджер записей

См. также

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

Эта небольшая статья - некоторого рода шпаргалка по файловым потокам: как и зачем с ними работать, какие преимущества это дает.

23.06.2024    9410    bayselonarrend    20    

158

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

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

2 стартмани

15.02.2024    13185    266    ZAOSTG    87    

115

Механизмы платформы 1С Программист Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    24964    SeiOkami    48    

136

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    16135    YA_418728146    8    

170

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

Рассмотрим новую возможность 8.3.24 и как её можно эффективно использовать

27.06.2023    28241    SeiOkami    32    

116

Запросы HighLoad оптимизация Программист Запросы Бесплатно (free)

Многие знают, что для ускорения работы запроса нужно «изучить план». При этом сам план обычно обескураживает: куча разноцветных иконок и стрелочек; ничего не понятно, но очень интересно! Аналитик производительности Александр Денисов на конференции Infostart Event 2021 Moscow Premiere рассказал, как выполняется план запроса и что нужно сделать, чтобы с его помощью находить проблемы производительности.

20.06.2023    30773    Филин    37    

119

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

Мало кто знает, что поле "Глобального поиска" в 1С можно доработать. Добавить свои варианты поиска, кнопочки в результатах и даже целые пользовательские меню.

27.03.2023    9088    SeiOkami    10    

143
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Strobe 28.03.24 12:25 Сейчас в теме
А если открывать транзакцию принудительно перед записью пачки сообщений в регистр и фиксировать ее после записи всей пачки - будет быстрее запись происходить, т.к. не будет на каждую запись отдельная транзакция в БД фиксироваться
3. starik-2005 3096 28.03.24 13:40 Сейчас в теме
(1)
транзакцию
Транзакция быстрее работала в файловой 7.7, т.к. не записывала на диск ничего до ее фиксации. База данных фиксирует все записи внутри транзакции с такой же скоростью, что и вне ее. Более того, запись объектов в СУБД и так происходит в единой транзакции, и если обернуть эту транзакцию сверху общей, то это вообще ничего не меняет.
Так что пора бы уже забыть про 7.7.
4. Strobe 28.03.24 15:44 Сейчас в теме
(3) что такое 7.7?

Я конкретно про такой лайфхак:
https://youtu.be/4uzD03_h288?t=2582

Более того, запись объектов в СУБД и так происходит в единой транзакции
- тут не понятно, какой "единой" и кто ее инициирует?
Dimkasan; dsdred; +2 Ответить
2. dsdred 3755 28.03.24 12:39 Сейчас в теме
(1) Я исходил из того, что сообщения регистрируются не пачками, а по штучно.
При использовании для регистрации сообщений механизм пост обработки Истории данных, происходит поштучка, а я именно так данные и регистрирую на текущем месте.

В любом случае я приложил весь код, если будет желание можно дописать и поэкспериментировать.
5. Lars Ulrich 625 28.03.24 16:06 Сейчас в теме
Может тогда стоило и со справочником сравнить. На СУБД всё едино - таблицы, но для платформы справочники функционально менее нагружены должны быть. И вот тут уже явную транзакцию можно использовать для набора.
triviumfan; +1 Ответить
11. zhichkin 1531 28.03.24 17:50 Сейчас в теме
(5) В своё время использовал именно справочники для регистрации исходящих сообщений. Однако, если в конфигурации используется подсистема БСП "Управление доступом", то это, при каждой записи элемента такого справочника, порождает дополнительные накладные расходы и нагрузку, что вообще неочевидно. Приходится как-то шаманить и что-то с этим делать. В итоге решил для себя использовать запись в регистры сведений в режиме вставки. Подробнее в моём комментарии (9)
6. dsdred 3755 28.03.24 16:15 Сейчас в теме
(5) чаще всего все таки регистры используют для пакетов. Поэтому сравниваю с ними.
7. Lars Ulrich 625 28.03.24 16:25 Сейчас в теме
(6) это понятно, но вдруг перевернем сознание, раз мы за скорость )))
Для тех же пакетов-то по сути возможность работы с наборами или срезами не нужна, поэтому справочник противоречит скорее сложившейся в голове модели.
8. dsdred 3755 28.03.24 17:05 Сейчас в теме
(7) Мы не только за скорость но и за удобства. В сообщениях сервисов интеграции вся структура уже продумана и есть параметры в которые можно записывать доп информацию. На регистрах по нормальному так не сделать.
Побольшему счету сообщения сервисов интеграции созданы для фиксации изменений в виде сообщений. Механизм придуман под интеграции изначально. Когда я в предыдущих статьях про него рассказывал получил несколько высказываний от тех кто привык к регистрам. И вопросы по скорости тоже были.
Так и родилась статья.

П.С. А на справочниках я на одном крупном предприятии видел обмены. Там была очень страшная самописная конфигурация с отвратительным качеством.
9. zhichkin 1531 28.03.24 17:10 Сейчас в теме
Спасибо большое за Вашу работу!

Уточните, пожалуйста, запись набора регистра сведений выполнялась в режиме замещения, то есть получается так, что сначала удаляются все записи в регистре сведений, а затем пишется набор с n-ым количеством записей ?

Самый быстрый вариант записи в регистр сведений был в своё время описан в статье Сергея Носкова.
Код выглядит вот так (объяснение в статье по ссылке):
Набор.ОбменДанными.Загрузка = Истина;
Набор.Записать(Ложь);

Обычно для регистрации исходящих данных к обмену при высоко нагруженных базах используют именно этот вариант записи в регистр сведений (в режиме вставки).
14. dsdred 3755 28.03.24 21:20 Сейчас в теме
(9)
Спасибо большое за Вашу работу!

Рад, что статья понравилась.

Уточните, пожалуйста, запись набора регистра сведений выполнялась в режиме замещения, то есть получается так, что сначала удаляются все записи в регистре сведений, а затем пишется набор с n-ым количеством записей ?

Да я очищал регистр, потом делал три замера по 10000 записей с набором. После замера опять очищал регистр и делал три замера по 10000 записей с менеджером.
Записи писал поштучно, так как максимально делал приближено к созданию сообщений на основе пост обработки Истории Данных.

Самый быстрый вариант записи в регистр сведений был в своё время описан в статье Сергея Носкова.
Код выглядит вот так (объяснение в статье по ссылке):

В принципе можно провести замер и так, там чуть чуть код поправить конфигурацию.

Спасибо за замечание.
19. DAAbramov 10 01.04.24 10:24 Сейчас в теме
(9) этот вариант начиная с какой-то версии платформы (15-16) уже не актуален, платформа этот запрос теперь делает в любом случае.
10. Lars Ulrich 625 28.03.24 17:24 Сейчас в теме
(8) мысль же не в сопротивлении сервисам интеграции, а в сравнении подкапотной реализации, которую мы не видим.
Качество реализации ведь не зависит от самих справочников как таковых. В статьях структура СУБД приводится практически идентичная для разных метаданных. Условно, вложите одну и ту же удобную структуру данных и результат должен быть как минимум близким по качеству. Или возьмите справочник, напишите в менеджер функцию поиска среза последних, получите условный регистр сведений: та же функциональность, то же удобство. В платформу добавляют функциональность, которая часто используется, облегчая труд, улучшая качество конечных продуктов, но и некоторым образом загоняя в рамки.
16. dsdred 3755 28.03.24 21:26 Сейчас в теме
(10)На сообщения сервисов интеграций ничего лишнего не повешено.
Нет ни подписок и прочих вещей, поэтому я думаю что для обменов они прям очень хорошее нововведение.
12. Lars Ulrich 625 28.03.24 18:11 Сейчас в теме
(11) про контекст БСП ничего не скажу, а скорее даже соглашусь , что он может быть перегружен для конкретных задач. Но если дело только в режиме обмена данными, то он доступен для разных типов метаданных, в т.ч справочников.
13. Cmapnep 19 28.03.24 20:23 Сейчас в теме
Надеялся, что отрыв будет больше, но 10-20% тоже неслабый прирост
В общем будем знать и использовать по мере необходимости
Еще раз спасибо за проделанную работу и серьезный подход к исследованию!
kote; dsdred; +2 Ответить
15. dsdred 3755 28.03.24 21:24 Сейчас в теме
(13)Рад что статья понравилась.

Не забывайте, что в реальных базах на регистры могут быть повешены подписки на события, различные проверки, создание версий, блокировки. Поэтому на чистой базе 10-20% это очень прилично.
17. zhichkin 1531 29.03.24 01:50 Сейчас в теме
Статья размещена а разделе highload. По этой причине, прошу не судить строго, но считаю необходимым добавить следующее.
Оба способа формирования очереди исходящих сообщений, описанные в статье, на уровне СУБД выполняют команду INSERT в кластерный индекс. Это очень важный момент!
Идеальным кластерным индексом в таком сценарии использования должен быть индекс, имеющий следующие требования к своему первичному ключу:
1. Минимально возможный размер.
2. Последовательный рост значений.
Например, таким идеальным ключом является число, но точно не случайно генерируемый уникальный идентификатор.
На практике при highload обменах обычного integer (4 байта) не хватает (примерно 4 млрд. значений). Используется тип biginteger (8 байт).
Таким образом, для 1С идельным регистром сведений, который используется как таблица-очередь, является независимый регистр сведений, имеющий одно измерение с типом данных Число(15,0) - 7 байт для SQL Server и 8 байт для PostgreSQL.
Как "заставить" 1С генерировать достаточно быстро последовательные числа в высоко конкурентной среде... это отдельная тема =)
Кроме всего прочего очень важным вопросом является именно последовательное потребление записей из таблиц-очередей с дальнейшим их удалением из того же самого кластерного индекса...
triviumfan; Dimkasan; senshib; Oxygraphis; JohnyDeath; Cmapnep; dsdred; +7 Ответить
18. dsdred 3755 29.03.24 07:40 Сейчас в теме
(17) Спасибо за дополнение.
20. TMV 14 02.04.24 14:26 Сейчас в теме
(17)
Как "заставить" 1С генерировать достаточно быстро последовательные числа в высоко конкурентной среде... это отдельная тема =)
Интересное замечание. Есть у вас какие-то наработки?
21. zhichkin 1531 02.04.24 17:10 Сейчас в теме
(20) Конечно же есть =) Если коротко, то есть такой объект СУБД SEQUENCE (реализован как в SQL Server, так и в PostgreSQL). Подробнее могу рассказать здесь
22. Cyberhawk 135 11.04.24 08:33 Сейчас в теме
можно сказать, что механизм по подготовке сообщений к отправке на «Сообщениях сервисов интеграции» является быстрее, чем то же самое делать на регистрах
А насколько быстрее?
23. dsdred 3755 11.04.24 08:37 Сейчас в теме
(22)Доброе утро.
В замерах все указано.

Замер с пустым телом сообщения в один поток:
Сервисы интеграции показали себя лучше регистров, запись прошла примерно на 17-19% быстрее.

и т.д.
Оставьте свое сообщение