Я наткнулся на вопрос в репозитории 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>
, но как это сделать внутри кода?