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

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

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

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -5,7 +5,33 @@
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]]
... ... @@ -39,6 +39,7 @@
39 39  (% style="width:1267px" %)
40 40  |ActivitySource|(% style="width:1082px" %)
41 41  |Activity|(% style="width:1082px" %)(((
68 +(((
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" %)
75 +|(% 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  )))
79 +
80 +(((
81 +В момент вызова Dispose activity фиксирует остановку и выполняется оповещение:
82 +(Activity -> ActivitySource -> ActivityListener -> OpenTelemetry.SpanProcessor -> OpenTelemetry.Exporter).
83 +В случае синхронного экспорта значений, первичная установка соединения может занять сравнительно много времени.
84 +)))
85 +)))
52 52  |ActivityListener|(% style="width:1082px" %)
53 53  |ActivityEvent|(% style="width:1082px" %)
54 54  |ActivityLink|(% style="width:1082px" %)