aboutsummaryrefslogtreecommitdiff
path: root/src/zenserver/stats/statsreporter.cpp
diff options
context:
space:
mode:
authorStefan Boberg <[email protected]>2023-10-25 12:21:51 +0200
committerGitHub <[email protected]>2023-10-25 12:21:51 +0200
commit0b220255724020daea18ddb559f5edf3fdb1621b (patch)
tree7809227752c15d90111c4e600d80b59d90ad25d2 /src/zenserver/stats/statsreporter.cpp
parentNew rotating file logger that keeps on running regardless of errors (#495) (diff)
downloadzen-0b220255724020daea18ddb559f5edf3fdb1621b.tar.xz
zen-0b220255724020daea18ddb559f5edf3fdb1621b.zip
statsd metrics reporting (#496)
added support for reporting metrics via statsd style UDP messaging, which is supported by many monitoring solution providers this change adds reporting only of three cache related metrics (hit/miss/put) but this should be extended to include more metrics after additional evaluation
Diffstat (limited to 'src/zenserver/stats/statsreporter.cpp')
-rw-r--r--src/zenserver/stats/statsreporter.cpp60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/zenserver/stats/statsreporter.cpp b/src/zenserver/stats/statsreporter.cpp
new file mode 100644
index 000000000..5d5ef4bfa
--- /dev/null
+++ b/src/zenserver/stats/statsreporter.cpp
@@ -0,0 +1,60 @@
+// Copyright Epic Games, Inc. All Rights Reserved.
+
+#include "statsreporter.h"
+
+#include <zencore/logging.h>
+#include <zennet/statsdclient.h>
+
+namespace zen {
+
+StatsReporter::StatsReporter()
+{
+}
+
+StatsReporter::~StatsReporter()
+{
+}
+
+void
+StatsReporter::Initialize(const ZenStatsConfig& Config)
+{
+ RwLock::ExclusiveLockScope _(m_Lock);
+
+ if (Config.Enabled)
+ {
+ ZEN_INFO("initializing stats reporter: {}:{}", Config.StatsdHost, Config.StatsdPort)
+ m_Statsd = CreateStatsDaemonClient(Config.StatsdHost, gsl::narrow<uint16_t>(Config.StatsdPort));
+ m_Statsd->SetMessageSize(1500, false);
+ }
+}
+
+void
+StatsReporter::Shutdown()
+{
+ RwLock::ExclusiveLockScope _(m_Lock);
+ m_Statsd.reset();
+}
+
+void
+StatsReporter::AddProvider(StatsProvider* Provider)
+{
+ RwLock::ExclusiveLockScope _(m_Lock);
+ m_Providers.push_back(Provider);
+}
+
+void
+StatsReporter::ReportStats()
+{
+ RwLock::ExclusiveLockScope _(m_Lock);
+ if (m_Statsd)
+ {
+ for (StatsProvider* Provider : m_Providers)
+ {
+ Provider->ReportMetrics(*m_Statsd);
+ }
+
+ m_Statsd->Flush();
+ }
+}
+
+} // namespace zen