-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathStatCommand.cs
More file actions
103 lines (91 loc) · 3.27 KB
/
StatCommand.cs
File metadata and controls
103 lines (91 loc) · 3.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
using System;
using System.Collections.Generic;
using System.Threading;
using NATS.Client;
using NLog;
namespace nats_tools
{
public class StatCommand : AbstractListenCommand<StatOptions>
{
private new static Logger Logger { get; } = LogManager.GetCurrentClassLogger();
private Thread logThread;
private bool stopRequest;
public DateTime StartDate { get; }
private readonly Dictionary<string, MessageStat> statBySubject = new Dictionary<string, MessageStat>();
public StatCommand() : base(Logger)
{
StartDate = DateTime.Now;
logThread = new Thread(Start)
{
Name = "Nats Stat Log"
};
logThread.Start();
}
private void Start()
{
var period = TimeSpan.FromMilliseconds(Options.Period);
DateTime nextTime = DateTime.Now + period;
while (!stopRequest)
{
var now = DateTime.Now;
if (now > nextTime)
{
nextTime = now + period;
var totalTimeInS = (now - StartDate).TotalSeconds;
Logger.Info("-----------------------------------------------------------------------------------------------------");
Logger.Info(MessageStat.Header);
Logger.Info("-----------------------------------------------------------------------------------------------------");
foreach (var stat in statBySubject.Values)
{
Logger.Info(stat.ToString(totalTimeInS));
stat.Reset();
}
}
Thread.Sleep(100);
}
}
protected override void OnMessage(object sender, MsgHandlerEventArgs e)
{
var subject = e.Message.Subject;
lock (statBySubject)
{
if (!statBySubject.TryGetValue(subject, out var stat))
{
stat = new MessageStat(subject);
statBySubject[subject] = stat;
}
stat.Update(e.Message.Data.Length); }
}
protected override void Dispose()
{
stopRequest = true;
}
}
internal class MessageStat
{
public static string Header { get; } = " Count Size DeltaC DeltaS Count/s Size/s Subject";
public string Subject { get; }
public int Count { get; set; }
public long Size { get; set; }
public int PrevCount { get; set; }
public long PrevSize { get; set; }
public MessageStat(string subject)
{
Subject = subject;
}
public void Update(in int size)
{
Size += size;
Count++;
}
public void Reset()
{
PrevCount = Count;
PrevSize = Size;
}
public string ToString(double totalTimeInS)
{
return $"{Count,6:###,##0} {Size,12:###,###,##0} {Count-PrevCount,6:###,##0} {Size-PrevSize,12:###,###,##0} {Count/totalTimeInS,9:###,##0.00} {Size/totalTimeInS,12:###,###,##0.00} {Subject}";
}
}
}