Аннотации
&Наблюдаемый — трассировка методов
Автоматически создаёт span OpenTelemetry вокруг вызовов метода.
Размещение на отдельном методе инструментирует только его:
&Желудь
Процедура ПриСозданииОбъекта()
КонецПроцедуры
&Наблюдаемый("orders.process")
Функция ОбработатьЗаказ(ИдЗаказа) Экспорт
Возврат СформироватьОтвет(ИдЗаказа);
КонецФункцииРазмещение на конструкторе инструментирует все экспортные методы класса:
&Желудь
&Наблюдаемый
Процедура ПриСозданииОбъекта()
КонецПроцедуры
Функция ОбработатьЗаказ(ИдЗаказа) Экспорт
Возврат СформироватьОтвет(ИдЗаказа);
КонецФункцииПараметры аннотации:
| Параметр | По умолчанию | Описание |
|---|---|---|
Значение | "ИмяБина.ИмяМетода" | Имя span'а |
ВидСпана | internal | Вид span'а: internal, server, client, producer, consumer |
Пример с явным видом спана:
&Желудь
&Наблюдаемый(ВидСпана = "server")
Процедура ПриСозданииОбъекта()
КонецПроцедуры&АтрибутСпана — атрибуты параметров
Добавляет значение параметра метода как атрибут текущего span'а. Используется совместно с &Наблюдаемый:
&Наблюдаемый
Функция ОбработатьЗаказ(&АтрибутСпана("order.id") ИдЗаказа, Данные) Экспорт
// span получит атрибут order.id = значение ИдЗаказа
Возврат СформироватьОтвет(ИдЗаказа);
КонецФункцииЕсли Значение не указано — в качестве ключа атрибута используется имя параметра:
&АтрибутСпана // ключ = "ИдЗаказа"
&АтрибутСпана("order.id") // ключ = "order.id"&Замеряемый — измерение длительности
Записывает длительность (в мс) каждого вызова метода в гистограмму OTel.
Атрибуты гистограммы: code.function.name, code.namespace, exception (при ошибке).
&Желудь
Процедура ПриСозданииОбъекта()
КонецПроцедуры
&Замеряемый("payments.process.duration")
Функция ОбработатьПлатёж(Данные) Экспорт
Возврат ПровестиПлатёж(Данные);
КонецФункцииРазмещение на конструкторе инструментирует все экспортные методы:
&Желудь
&Замеряемый
Процедура ПриСозданииОбъекта()
КонецПроцедурыПараметры аннотации:
| Параметр | По умолчанию | Описание |
|---|---|---|
Значение | "ИмяБина.ИмяМетода.duration" | Имя метрики (должно быть ASCII) |
Имена методов на кириллице транслитерируются автоматически.
&Подсчитываемый — счётчик вызовов
Инкрементирует счётчик OTel при каждом вызове метода.
Атрибуты счётчика: code.function.name, code.namespace, result (success/failure), exception (при ошибке).
&Желудь
Процедура ПриСозданииОбъекта()
КонецПроцедуры
&Подсчитываемый("api.requests")
Функция ОбработатьЗапрос(Запрос) Экспорт
Возврат СформироватьОтвет(Запрос);
КонецФункцииРазмещение на конструкторе инструментирует все экспортные методы:
&Желудь
&Подсчитываемый
Процедура ПриСозданииОбъекта()
КонецПроцедурыПараметры аннотации:
| Параметр | По умолчанию | Описание |
|---|---|---|
Значение | "ИмяБина.ИмяМетода.counted" | Имя метрики (должно быть ASCII) |
Имена методов на кириллице транслитерируются автоматически.
Комбинирование аннотаций
Аннотации можно комбинировать на одном методе:
&Желудь
Процедура ПриСозданииОбъекта()
КонецПроцедуры
&Наблюдаемый("orders.process")
&Замеряемый("orders.duration")
&Подсчитываемый("orders.count")
Функция ОбработатьЗаказ(&АтрибутСпана("order.id") ИдЗаказа) Экспорт
Возврат СформироватьОтвет(ИдЗаказа);
КонецФункции