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

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

<
От версии < 1.17 >
отредактировано Alexandr Fokin
на 2022/12/03 06:27
К версии < 2.3 >
отредактировано Alexandr Fokin
на 2022/12/13 19:07
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -1,13 +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 +System.Diagnostics Пространство имен
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]]
5 5  
8 +----
9 +
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 +
6 6  |(% colspan="2" rowspan="1" style="text-align:center; vertical-align:middle; width:59px" %)Metric|(% style="width:1278px" %)(((
7 7  System.Diagnostics.Metrics
8 8  [[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]]
9 9  
10 10  
40 +(% style="width:802px" %)
41 +|(% style="width:144px" %)NonObservable|(% style="width:657px" %)Хранит значение метрики самостоятельно
42 +|(% style="width:144px" %)Observable|(% style="width:657px" %)Использует внешний делегат, для получения текущего значения метрики
43 +
11 11  |(% colspan="1" rowspan="5" style="width:117px" %)Наблюдаемые инструменты|(% style="width:198px" %)Instrument
12 12  ObservableInstrument|(% style="width:957px" %)Базовый класс|(% style="width:957px" %)
13 13  |(% style="width:198px" %)Counter
... ... @@ -36,6 +36,7 @@
36 36  (% style="width:1267px" %)
37 37  |ActivitySource|(% style="width:1082px" %)
38 38  |Activity|(% style="width:1082px" %)(((
72 +(((
39 39  (% style="width:1048px" %)
40 40  |(% colspan="1" rowspan="2" style="width:31px" %)1|(% style="width:164px" %)OperationName|(% style="width:846px" %)Имя
41 41  |(% style="width:164px" %)Duration|(% style="width:846px" %)Длительность
... ... @@ -42,12 +42,19 @@
42 42  |(% colspan="1" rowspan="5" style="width:31px" %)2|(% style="width:164px" %)Tags|(% style="width:846px" %)Key-value коллекция
43 43  |(% style="width:164px" %)Baggage|(% style="width:846px" %)Key-value коллекция элементов, передаваемых дочерним Activity
44 44  |(% style="width:164px" %)Events|(% style="width:846px" %)Набор событий ActivityEvent.
45 -|(% style="width:164px" %)Context|(% style="width:846px" %)
46 -|(% style="width:164px" %)Links|(% style="width:846px" %)
79 +|(% style="width:164px" %)Context|(% style="width:846px" %)Набор атрибутов, идентифицирующих Activity.
80 +|(% style="width:164px" %)Links|(% style="width:846px" %)Набор ссылок ActivityLink.
47 47  |(% colspan="1" style="width:31px" %) |(% style="width:164px" %)Custom properties|(% style="width:846px" %)Коллекция прикрепленных объектов
48 48  )))
83 +
84 +(((
85 +В момент вызова Dispose activity фиксирует остановку и выполняется оповещение:
86 +(Activity -> ActivitySource -> ActivityListener -> OpenTelemetry.SpanProcessor -> OpenTelemetry.Exporter).
87 +)))
88 +)))
49 49  |ActivityListener|(% style="width:1082px" %)
50 50  |ActivityEvent|(% style="width:1082px" %)
91 +|ActivityLink|(% style="width:1082px" %)
51 51  )))
52 52  
53 53