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

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

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

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -12,8 +12,24 @@
12 12  1. ActivitySource не создает экземпляры Activity (возвращает null), если нет ни одного активного ActivityListener.
13 13  1. **!!!** Нижеприведенный код после публикации сборки (и в Release и в Debug) может никогда не выполниться, в случае, если к полю _Listener (и к классу FakeListener) нет других обращений.
14 14  И Activity не будут создаваться.
15 -{{code language="с#"}}private static readonly FakeListener _Listener = new FakeListener();{{/code}}
15 +{{code language="с#"}}private static readonly FakeListener _Listener = new FakeListener();
16 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 +
17 17  ----
18 18  
19 19  |(% colspan="2" rowspan="1" style="text-align:center; vertical-align:middle; width:59px" %)Metric|(% style="width:1278px" %)(((
... ... @@ -49,6 +49,7 @@
49 49  (% style="width:1267px" %)
50 50  |ActivitySource|(% style="width:1082px" %)
51 51  |Activity|(% style="width:1082px" %)(((
68 +(((
52 52  (% style="width:1048px" %)
53 53  |(% colspan="1" rowspan="2" style="width:31px" %)1|(% style="width:164px" %)OperationName|(% style="width:846px" %)Имя
54 54  |(% style="width:164px" %)Duration|(% style="width:846px" %)Длительность
... ... @@ -55,10 +55,17 @@
55 55  |(% colspan="1" rowspan="5" style="width:31px" %)2|(% style="width:164px" %)Tags|(% style="width:846px" %)Key-value коллекция
56 56  |(% style="width:164px" %)Baggage|(% style="width:846px" %)Key-value коллекция элементов, передаваемых дочерним Activity
57 57  |(% style="width:164px" %)Events|(% style="width:846px" %)Набор событий ActivityEvent.
58 -|(% style="width:164px" %)Context|(% style="width:846px" %)
75 +|(% style="width:164px" %)Context|(% style="width:846px" %)Набор атрибутов, идентифицирующих Activity.
59 59  |(% style="width:164px" %)Links|(% style="width:846px" %)Набор ссылок ActivityLink.
60 60  |(% colspan="1" style="width:31px" %) |(% style="width:164px" %)Custom properties|(% style="width:846px" %)Коллекция прикрепленных объектов
61 61  )))
79 +
80 +(((
81 +В момент вызова Dispose activity фиксирует остановку и выполняется оповещение:
82 +(Activity -> ActivitySource -> ActivityListener -> OpenTelemetry.SpanProcessor -> OpenTelemetry.Exporter).
83 +В случае синхронного экспорта значений, первичная установка соединения может занять сравнительно много времени.
84 +)))
85 +)))
62 62  |ActivityListener|(% style="width:1082px" %)
63 63  |ActivityEvent|(% style="width:1082px" %)
64 64  |ActivityLink|(% style="width:1082px" %)