From 2d4c80ef9a032c003e446a81ab9253c56ad88ae0 Mon Sep 17 00:00:00 2001 From: ivanmorozov333 Date: Fri, 20 Sep 2024 16:38:16 +0300 Subject: [PATCH] reduce memory in schemas loading (#9548) --- ydb/core/tx/columnshard/tables_manager.cpp | 40 ++++++++++++---------- ydb/core/tx/columnshard/tables_manager.h | 11 ++++-- 2 files changed, 29 insertions(+), 22 deletions(-) diff --git a/ydb/core/tx/columnshard/tables_manager.cpp b/ydb/core/tx/columnshard/tables_manager.cpp index a138e26d74b7..6d657cebcb6c 100644 --- a/ydb/core/tx/columnshard/tables_manager.cpp +++ b/ydb/core/tx/columnshard/tables_manager.cpp @@ -44,10 +44,7 @@ bool TTablesManager::FillMonitoringReport(NTabletFlatExecutor::TTransactionConte } bool TTablesManager::InitFromDB(NIceDb::TNiceDb& db) { - using TTableVersionsInfo = TVersionedSchema; - THashMap schemaPresets; - THashMap tableVersions; { TMemoryProfileGuard g("TTablesManager/InitFromDB::Tables"); auto rowset = db.Table().Select(); @@ -64,7 +61,6 @@ bool TTablesManager::InitFromDB(NIceDb::TNiceDb& db) { PathsToDrop.insert(table.GetPathId()); } - AFL_VERIFY(tableVersions.emplace(table.GetPathId(), TTableVersionsInfo()).second); AFL_VERIFY(Tables.emplace(table.GetPathId(), std::move(table)).second); if (!rowset.Next()) { @@ -115,7 +111,6 @@ bool TTablesManager::InitFromDB(NIceDb::TNiceDb& db) { rowset.GetValue()); auto& table = Tables[pathId]; - auto& versionsInfo = tableVersions[pathId]; NKikimrTxColumnShard::TTableVersionInfo versionInfo; Y_ABORT_UNLESS(versionInfo.ParseFromString(rowset.GetValue())); AFL_DEBUG(NKikimrServices::TX_COLUMNSHARD)("event", "load_table_version")("path_id", pathId)("snapshot", version)("version", versionInfo.HasSchema() ? versionInfo.GetSchema().GetVersion() : -1); @@ -125,15 +120,17 @@ bool TTablesManager::InitFromDB(NIceDb::TNiceDb& db) { auto& ttlSettings = versionInfo.GetTtlSettings(); if (ttlSettings.HasEnabled()) { auto vIt = lastVersion.find(pathId); - if (vIt == lastVersion.end() || vIt->second < version) { + if (vIt == lastVersion.end()) { + vIt = lastVersion.emplace(pathId, version).first; + } + if (vIt->second <= version) { TTtl::TDescription description(ttlSettings.GetEnabled()); Ttl.SetPathTtl(pathId, std::move(description)); - lastVersion.emplace(pathId, version); + vIt->second = version; } } } table.AddVersion(version); - versionsInfo.AddVersion(version, versionInfo); if (!rowset.Next()) { return false; } @@ -152,8 +149,7 @@ bool TTablesManager::InitFromDB(NIceDb::TNiceDb& db) { Y_ABORT_UNLESS(schemaPresets.contains(id)); auto& preset = schemaPresets[id]; NOlap::TSnapshot version( - rowset.GetValue(), - rowset.GetValue()); + rowset.GetValue(), rowset.GetValue()); TSchemaPreset::TSchemaPresetVersionInfo info; Y_ABORT_UNLESS(info.ParseFromString(rowset.GetValue())); @@ -166,21 +162,27 @@ bool TTablesManager::InitFromDB(NIceDb::TNiceDb& db) { } TMemoryProfileGuard g("TTablesManager/InitFromDB::Other"); - for (const auto& [id, preset] : schemaPresets) { + for (auto& [id, preset] : schemaPresets) { if (isFakePresetOnly) { Y_ABORT_UNLESS(id == 0); } else { Y_ABORT_UNLESS(id > 0); } - for (const auto& [version, schemaInfo] : preset.GetVersionsById()) { - if (schemaInfo.HasSchema()) { - AFL_INFO(NKikimrServices::TX_COLUMNSHARD)("event", "index_schema")("preset_id", id)("snapshot", version)("version", schemaInfo.GetSchema().GetVersion()); - if (!PrimaryIndex) { - PrimaryIndex = std::make_unique(TabletId, StoragesManager, preset.GetMinVersionForId(schemaInfo.GetSchema().GetVersion()), schemaInfo.GetSchema()); - } else { - PrimaryIndex->RegisterSchemaVersion(preset.GetMinVersionForId(schemaInfo.GetSchema().GetVersion()), schemaInfo.GetSchema()); - } + for (auto it = preset.MutableVersionsById().begin(); it != preset.MutableVersionsById().end();) { + const auto version = it->first; + const auto& schemaInfo = it->second; + if (!schemaInfo.HasSchema()) { + continue; + } + AFL_INFO(NKikimrServices::TX_COLUMNSHARD)("event", "index_schema")("preset_id", id)("snapshot", version)( + "version", schemaInfo.GetSchema().GetVersion()); + if (!PrimaryIndex) { + PrimaryIndex = std::make_unique( + TabletId, StoragesManager, preset.GetMinVersionForId(schemaInfo.GetSchema().GetVersion()), schemaInfo.GetSchema()); + } else { + PrimaryIndex->RegisterSchemaVersion(preset.GetMinVersionForId(schemaInfo.GetSchema().GetVersion()), schemaInfo.GetSchema()); } + it = preset.MutableVersionsById().erase(it); } } for (auto&& i : Tables) { diff --git a/ydb/core/tx/columnshard/tables_manager.h b/ydb/core/tx/columnshard/tables_manager.h index 1481882e41f8..01643fe8db9a 100644 --- a/ydb/core/tx/columnshard/tables_manager.h +++ b/ydb/core/tx/columnshard/tables_manager.h @@ -28,6 +28,10 @@ class TVersionedSchema { return VersionsById; } + TMap& MutableVersionsById() { + return VersionsById; + } + NOlap::TSnapshot GetMinVersionForId(const ui64 sVersion) const { auto it = MinVersionById.find(sVersion); Y_ABORT_UNLESS(it != MinVersionById.end()); @@ -42,10 +46,11 @@ class TVersionedSchema { VersionsById.emplace(ssVersion, versionInfo); Y_ABORT_UNLESS(Versions.emplace(snapshot, ssVersion).second); - if (MinVersionById.contains(ssVersion)) { - MinVersionById.emplace(ssVersion, std::min(snapshot, MinVersionById.at(ssVersion))); - } else { + auto it = MinVersionById.find(ssVersion); + if (it == MinVersionById.end()) { MinVersionById.emplace(ssVersion, snapshot); + } else { + it->second = std::min(snapshot, it->second); } } };