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

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

<
От версии < 1.21 >
отредактировано Alexandr Fokin
на 2022/12/06 10:46
К версии < 2.1 >
отредактировано Alexandr Fokin
на 2022/12/12 12:49
>
Изменить комментарий: Renamed back-links.

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -1,6 +1,6 @@
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]]
... ... @@ -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" %)