Изменения документа System. Diagnostics

Редактировал(а) Alexandr Fokin 2022/12/30 00:19

<
От версии < 1.20 >
отредактировано Alexandr Fokin
на 2022/12/03 07:10
К версии < 2.2 >
отредактировано Alexandr Fokin
на 2022/12/13 10:33
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -1,16 +1,46 @@
1 1  System.Diagnostics
2 2  
3 -[[Open Telemetry>>doc:Разработка.Логи, трассировка, метрики, мониторинг.Трассировка.Open Telemetry.WebHome]]
3 +[[Open Telemetry>>doc:Разработка.Логи, трассировка, метрики, мониторинг.Open Telemetry.WebHome]]
4 4  
5 5  System.Diagnostics Пространство имен
6 6  [[https:~~/~~/learn.microsoft.com/ru-ru/dotnet/api/system.diagnostics?view=net-7.0>>https://learn.microsoft.com/ru-ru/dotnet/api/system.diagnostics?view=net-7.0]]
7 7  
8 +----
8 8  
10 +Замечания:
11 +
12 +1. ActivitySource не создает экземпляры Activity (возвращает null), если нет ни одного активного ActivityListener.
13 +1. **!!!** Нижеприведенный код после публикации сборки (и в Release и в Debug) может никогда не выполниться, в случае, если к полю _Listener (и к классу FakeListener) нет других обращений.
14 +И Activity не будут создаваться.
15 +{{code language="с#"}}private static readonly FakeListener _Listener = new FakeListener();
16 +
17 +internal class FakeListener
18 +{
19 + public FakeListener()
20 + {
21 + ActivityListener = new ActivityListener()
22 + {
23 + ShouldListenTo = (source) => true,
24 + SampleUsingParentId = (ref ActivityCreationOptions<string> activityOptions) => ActivitySamplingResult.AllData,
25 + Sample = (ref ActivityCreationOptions<ActivityContext> activityOptions) => ActivitySamplingResult.AllData
26 + };
27 + ActivitySource.AddActivityListener(
28 + ActivityListener
29 + );
30 + }
31 +}{{/code}}
32 +
33 +----
34 +
9 9  |(% colspan="2" rowspan="1" style="text-align:center; vertical-align:middle; width:59px" %)Metric|(% style="width:1278px" %)(((
10 10  System.Diagnostics.Metrics
11 11  [[https:~~/~~/learn.microsoft.com/ru-ru/dotnet/api/system.diagnostics.metrics?view=net-7.0>>https://learn.microsoft.com/ru-ru/dotnet/api/system.diagnostics.metrics?view=net-7.0]]
12 12  
13 13  
40 +(% style="width:802px" %)
41 +|(% style="width:144px" %)NonObservable|(% style="width:657px" %)Хранит значение метрики самостоятельно
42 +|(% style="width:144px" %)Observable|(% style="width:657px" %)Использует внешний делегат, для получения текущего значения метрики
43 +
14 14  |(% colspan="1" rowspan="5" style="width:117px" %)Наблюдаемые инструменты|(% style="width:198px" %)Instrument
15 15  ObservableInstrument|(% style="width:957px" %)Базовый класс|(% style="width:957px" %)
16 16  |(% style="width:198px" %)Counter
... ... @@ -39,6 +39,7 @@
39 39  (% style="width:1267px" %)
40 40  |ActivitySource|(% style="width:1082px" %)
41 41  |Activity|(% style="width:1082px" %)(((
72 +(((
42 42  (% style="width:1048px" %)
43 43  |(% colspan="1" rowspan="2" style="width:31px" %)1|(% style="width:164px" %)OperationName|(% style="width:846px" %)Имя
44 44  |(% style="width:164px" %)Duration|(% style="width:846px" %)Длительность
... ... @@ -45,10 +45,17 @@
45 45  |(% colspan="1" rowspan="5" style="width:31px" %)2|(% style="width:164px" %)Tags|(% style="width:846px" %)Key-value коллекция
46 46  |(% style="width:164px" %)Baggage|(% style="width:846px" %)Key-value коллекция элементов, передаваемых дочерним Activity
47 47  |(% style="width:164px" %)Events|(% style="width:846px" %)Набор событий ActivityEvent.
48 -|(% style="width:164px" %)Context|(% style="width:846px" %)
79 +|(% style="width:164px" %)Context|(% style="width:846px" %)Набор атрибутов, идентифицирующих Activity.
49 49  |(% style="width:164px" %)Links|(% style="width:846px" %)Набор ссылок ActivityLink.
50 50  |(% colspan="1" style="width:31px" %) |(% style="width:164px" %)Custom properties|(% style="width:846px" %)Коллекция прикрепленных объектов
51 51  )))
83 +
84 +(((
85 +В момент вызова Dispose activity фиксирует остановку и выполняется оповещение:
86 +(Activity -> ActivitySource -> ActivityListener -> OpenTelemetry.SpanProcessor -> OpenTelemetry.Exporter).
87 +В случае синхронного экспорта значений, первичная установка соединения может занять сравнительно много времени.
88 +)))
89 +)))
52 52  |ActivityListener|(% style="width:1082px" %)
53 53  |ActivityEvent|(% style="width:1082px" %)
54 54  |ActivityLink|(% style="width:1082px" %)