summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorgalaxycrab <[email protected]>2022-09-20 14:02:34 +0300
committergalaxycrab <[email protected]>2022-09-20 14:02:34 +0300
commitbe898c78243c4941f216b219a06cdc85a0afe6c5 (patch)
tree7955dedf7d04f794a3c5469ffbdd24a966744341
parent82d81702d4bd8e8e781c5f358c50e32013459779 (diff)
Get quota in monitoring page
-rw-r--r--ydb/core/yq/libs/quota_manager/events/events.h2
-rw-r--r--ydb/core/yq/libs/quota_manager/quota_manager.cpp87
2 files changed, 84 insertions, 5 deletions
diff --git a/ydb/core/yq/libs/quota_manager/events/events.h b/ydb/core/yq/libs/quota_manager/events/events.h
index a3d0473bdb5..aded49f01af 100644
--- a/ydb/core/yq/libs/quota_manager/events/events.h
+++ b/ydb/core/yq/libs/quota_manager/events/events.h
@@ -74,7 +74,7 @@ struct TQuotaUsage {
TQuotaUsage(ui64 limit, const TInstant& limitUpdatedAt = Now()) : Limit(limit, limitUpdatedAt) {}
TQuotaUsage(ui64 limit, const TInstant& limitUpdatedAt, ui64 usage, const TInstant& usageUpdatedAt = Now())
: Limit(limit, limitUpdatedAt), Usage(NMaybe::TInPlace{}, usage, usageUpdatedAt) {}
- TQuotaUsage &operator=(const TQuotaUsage& other) = default;
+ TQuotaUsage& operator=(const TQuotaUsage& other) = default;
void Merge(const TQuotaUsage& other);
TString ToString() {
return (Usage ? std::to_string(Usage->Value) : "*") + "/" + std::to_string(Limit.Value);
diff --git a/ydb/core/yq/libs/quota_manager/quota_manager.cpp b/ydb/core/yq/libs/quota_manager/quota_manager.cpp
index b1a8186f70b..92a428d0da9 100644
--- a/ydb/core/yq/libs/quota_manager/quota_manager.cpp
+++ b/ydb/core/yq/libs/quota_manager/quota_manager.cpp
@@ -104,7 +104,7 @@ TString ToString(const std::vector<ui32>& v) {
return builder;
}
-TString ToString(const TQuotaMap& quota){
+TString ToString(const TQuotaMap& quota) {
if (quota.empty()) {
return "{}";
}
@@ -120,7 +120,7 @@ TString ToString(const TQuotaMap& quota){
return builder;
}
-TString ToString(const THashMap<TString, TQuotaCachedUsage>& usageMap){
+TString ToString(const THashMap<TString, TQuotaCachedUsage>& usageMap) {
if (usageMap.empty()) {
return "{}";
}
@@ -193,11 +193,12 @@ public:
private:
STRICT_STFUNC(StateFunc,
hFunc(TEvQuotaService::TQuotaGetRequest, Handle)
+ hFunc(TEvQuotaService::TQuotaGetResponse, Handle) // http monitoring
hFunc(TEvQuotaService::TQuotaChangeNotification, Handle)
hFunc(TEvQuotaService::TQuotaUsageResponse, Handle)
hFunc(TEvQuotaService::TQuotaLimitChangeResponse, Handle)
hFunc(TEvQuotaService::TQuotaSetRequest, Handle)
- hFunc(TEvQuotaService::TQuotaSetResponse, Handle)
+ hFunc(TEvQuotaService::TQuotaSetResponse, Handle) // http monitoring
hFunc(TEvents::TEvCallback, [](TEvents::TEvCallback::TPtr& ev) { ev->Get()->Callback(); } );
hFunc(NActors::TEvInterconnect::TEvNodesInfo, Handle)
hFunc(TEvQuotaService::TEvQuotaUpdateNotification, Handle)
@@ -706,12 +707,55 @@ private:
html << "</tr></thead><tbody>";
html << "<tr><td>Subject Type:</td><td>" << ev->Get()->SubjectType << "</td></tr>";
html << "<tr><td>Subject ID:</td><td>" << ev->Get()->SubjectId << "</td></tr>";
- for (auto& limit : ev->Get()->Limits) {
+ for (const auto& limit : ev->Get()->Limits) {
html << "<tr><td>" << limit.first << "</td><td>" << limit.second << "</td></tr>";
}
html << "</tbody></table>";
Send(HttpMonId, new NMon::TEvHttpInfoRes(html.Str()));
+ HttpMonId = NActors::TActorId();
+ }
+
+ void Handle(TEvQuotaService::TQuotaGetResponse::TPtr& ev) {
+
+ TStringStream html;
+ html << "<table class='table simple-table1 table-hover table-condensed'>";
+ html << "<thead><tr>";
+ html << "<th>Quota Get Response</th>";
+ html << "<th></th>";
+ html << "</tr></thead><tbody>";
+ html << "<tr><td>Subject Type:</td><td>" << ev->Get()->SubjectType << "</td></tr>\n";
+ html << "<tr><td>Subject ID:</td><td>" << ev->Get()->SubjectId << "</td></tr>\n";
+ html << "</tbody></table>\n";
+ html << "<br>";
+
+ html << "<table class='table simple-table1 table-hover table-condensed'>";
+ html << "<thead><tr>";
+ html << "<th>Metric Name</th>";
+ html << "<th>Limit Value</th>";
+ html << "<th>Updated At</th>";
+ html << "<th>Usage</th>";
+ html << "</tr></thead><tbody>";
+ for (const auto& [metricName, metricUsageInfo] : ev->Get()->Quotas) {
+ html << "<tr>";
+ html << "<td>" << metricName << "</td>";
+ html << "<td>" << metricUsageInfo.Limit.Value << "</td>";
+ if (metricUsageInfo.Limit.UpdatedAt) {
+ html << "<td>" << metricUsageInfo.Limit.UpdatedAt << "</td>";
+ } else {
+ html << "<td></td>";
+ }
+ if (metricUsageInfo.Usage) {
+ html << "<td>" << metricUsageInfo.Usage->Value << "</td>";
+ } else {
+ html << "<td></td>";
+ }
+ html << "</tr>\n";
+ }
+ html << "</tbody></table>";
+
+ Send(HttpMonId, new NMon::TEvHttpInfoRes(html.Str()));
+ HttpMonId = NActors::TActorId();
}
void Handle(NMon::TEvHttpInfo::TPtr& ev) {
@@ -734,6 +778,19 @@ private:
HttpMonId = ev->Sender;
return;
+ } else if (params.Has("get")) {
+ TString subjectId = params.Get("subject_id");
+ TString subjectType = params.Get("subject_type");
+ if (subjectType.empty()) {
+ subjectType = "cloud";
+ }
+
+ auto request = MakeHolder<TEvQuotaService::TQuotaGetRequest>(subjectType, subjectId);
+
+ Send(SelfId(), request.Release());
+
+ HttpMonId = ev->Sender;
+ return;
}
TStringStream html;
@@ -742,9 +799,31 @@ private:
html << "<p>Subject Type (defaulted to 'cloud'):<input name='subject_type' type='text'/></p>";
html << "<p>Quota Name:<input name='metric_name' type='text'/></p>";
html << "<p>New value:<input name='metric_value' type='number'/></p>";
+ html << "<button name='get' type='submit'><b>Get</b></button>";
html << "<button name='submit' type='submit'><b>Change</b></button>";
html << "</form>";
+ // Table with known metrics info
+ html << "<br>";
+ html << "<table class='table simple-table1 table-hover table-condensed'>";
+ html << "<thead><tr>";
+ html << "<th>Metric Name</th>";
+ html << "<th>Subject Type</th>";
+ html << "<th>Default Limit</th>";
+ html << "<th>Hard Limit</th>";
+ html << "</tr></thead><tbody>";
+ for (const auto& [subjectType, subjectMetricsInfo] : QuotaInfoMap) {
+ for (const auto& [metricName, quotaInfo] : subjectMetricsInfo) {
+ html << "<tr>";
+ html << "<td>" << metricName << "</td>";
+ html << "<td>" << subjectType << "</td>";
+ html << "<td>" << quotaInfo.DefaultLimit << "</td>";
+ html << "<td>" << quotaInfo.HardLimit << "</td>";
+ html << "</tr>\n";
+ }
+ }
+ html << "</tbody></table>";
+
Send(ev->Sender, new NMon::TEvHttpInfoRes(html.Str()));
}