Как получить доступ к счетчикам Npg sql внутри приложения NetCore - PullRequest
0 голосов
/ 19 февраля 2020

Я наткнулся на вопрос в репозитории Npg sql, что возможно собрать данные счетчиков: https://github.com/npgsql/npgsql/issues/1725

есть ли образцы или информация о том, как получить доступ к эти счетчики?

Обращаясь к следующей статье https://github.com/dotnet/diagnostics/blob/master/documentation/design-docs/eventcounters.md, я пытался следовать безуспешно и без данных только по счетчикам событий (например, idle-connections et c) CommandStart CommandEnd

 class Program
    {
        static void Main(string[] args)
        {
            var listener = new TestEventListener();

            while (true)
            {
                using var cn = new Npgsql.NpgsqlConnection("...");  cn.Open();
                var cmd = new NpgsqlCommand("select 1", cn); cmd.ExecuteNonQuery();
            }
        }
    }

    class TestEventListener : EventListener
    {
        private readonly EventLevel level = EventLevel.Verbose;

        protected override void OnEventWritten(EventWrittenEventArgs eventData)
        {
            Console.WriteLine($"{eventData.EventName}");

            if (eventData.EventName.Equals("EventCounters", StringComparison.OrdinalIgnoreCase))
            {
                for (var i = 0; i < eventData.Payload.Count; i++)
                {
                    if (eventData.Payload[i] is IDictionary<string, object> payload)
                    {
                        Console.WriteLine(payload);
                    }

                }
            }
        }

        protected override void OnEventSourceCreated(EventSource eventSource)
        {
            if (eventSource.Name.Equals("Npgsql"))
            {
                var refreshInterval = new Dictionary<string, string>()
                {
                    { "connection-pools", "1" },
                    { "idle-connections", "1" },
                    { "busy-connections", "1" }
                };

                EnableEvents(eventSource, level, EventKeywords.None, refreshInterval);
            }

            base.OnEventSourceCreated(eventSource);
        }
    }

Я вижу, что эти счетчики работают, если запустить dotnet counters monitor Npgsql -p <pid>, но как это сделать внутри кода?

1 Ответ

0 голосов
/ 20 февраля 2020

Ответ должен следовать за documentm и предоставить фактический аргумент, указанный в документе:

Dictionary<string, string> refreshInterval = new Dictionary<string, string>()
        {
            { "EventCounterIntervalSec", "1" }
        };
...