Замеряемый
Аннотация для автоматического замера длительности выполнения методов (аналог @Timed из Spring Boot).
Синтаксис
bsl
&Замеряемый[(Значение)]
Функция ИмяМетода(...) Экспорт
...
КонецФункцииПараметры
Значение
Тип: Строка (опционально)
Имя метрики. Должно соответствовать формату OTel (ASCII, точки как разделители). Если не указано, используется "ИмяБина.ИмяМетода.duration" с автоматической транслитерацией кириллицы.
Описание
Аннотация &Замеряемый оборачивает метод в декоратор, который:
- Фиксирует время начала вызова
- После завершения метода записывает длительность (в мс) в гистограмму OTel
- При исключении записывает длительность с атрибутом
exception
Атрибуты гистограммы: code.function.name, code.namespace, exception (при ошибке).
При размещении на конструкторе (вместе с &Желудь) инструментируются все экспортные методы класса.
Примеры
Инструментация одного метода
bsl
&Замеряемый("payments.process.duration")
Функция ОбработатьПлатёж(Данные) Экспорт
Возврат ПровестиПлатёж(Данные);
КонецФункцииИнструментация всех методов класса
bsl
&Желудь
&Замеряемый
Процедура ПриСозданииОбъекта()
КонецПроцедурыКомбинирование с другими аннотациями
bsl
&Наблюдаемый("orders.process")
&Замеряемый("orders.duration")
Функция ОбработатьЗаказ(ИдЗаказа) Экспорт
Возврат СформироватьОтвет(ИдЗаказа);
КонецФункцииСм. также
- Наблюдаемый — создание span'ов вокруг методов
- Подсчитываемый — счётчик вызовов методов
