#include "StorageSystemRemoteDataPaths.h" #include #include #include #include #include #include #include #include #include namespace DB { StorageSystemRemoteDataPaths::StorageSystemRemoteDataPaths(const StorageID & table_id_) : IStorage(table_id_) { StorageInMemoryMetadata storage_metadata; storage_metadata.setColumns(ColumnsDescription( { {"disk_name", std::make_shared()}, {"path", std::make_shared()}, {"cache_base_path", std::make_shared()}, {"local_path", std::make_shared()}, {"remote_path", std::make_shared()}, {"size", std::make_shared()}, {"refcount", std::make_shared()}, {"common_prefix_for_blobs", std::make_shared()}, {"cache_paths", std::make_shared(std::make_shared())}, })); setInMemoryMetadata(storage_metadata); } Pipe StorageSystemRemoteDataPaths::read( const Names & column_names, const StorageSnapshotPtr & storage_snapshot, SelectQueryInfo & /*query_info*/, ContextPtr context, QueryProcessingStage::Enum /*processed_stage*/, const size_t /*max_block_size*/, const size_t /*num_streams*/) { storage_snapshot->check(column_names); MutableColumnPtr col_disk_name = ColumnString::create(); MutableColumnPtr col_base_path = ColumnString::create(); MutableColumnPtr col_cache_base_path = ColumnString::create(); MutableColumnPtr col_local_path = ColumnString::create(); MutableColumnPtr col_remote_path = ColumnString::create(); MutableColumnPtr col_size = ColumnUInt64::create(); MutableColumnPtr col_refcount = ColumnUInt64::create(); MutableColumnPtr col_namespace = ColumnString::create(); MutableColumnPtr col_cache_paths = ColumnArray::create(ColumnString::create()); auto disks = context->getDisksMap(); for (const auto & [disk_name, disk] : disks) { if (disk->isRemote()) { std::vector remote_paths_by_local_path; disk->getRemotePathsRecursive("store", remote_paths_by_local_path); disk->getRemotePathsRecursive("data", remote_paths_by_local_path); FileCachePtr cache; if (disk->supportsCache()) cache = FileCacheFactory::instance().getByName(disk->getCacheName()).cache; for (const auto & [local_path, common_prefox_for_objects, storage_objects, refcount] : remote_paths_by_local_path) { for (const auto & object : storage_objects) { col_disk_name->insert(disk_name); col_base_path->insert(disk->getPath()); if (cache) col_cache_base_path->insert(cache->getBasePath()); else col_cache_base_path->insertDefault(); col_local_path->insert(local_path); col_remote_path->insert(object.remote_path); col_size->insert(object.bytes_size); col_refcount->insert(refcount); col_namespace->insert(common_prefox_for_objects); if (cache) { auto cache_paths = cache->tryGetCachePaths(cache->createKeyForPath(object.remote_path)); col_cache_paths->insert(Array(cache_paths.begin(), cache_paths.end())); } else { col_cache_paths->insertDefault(); } } } } } Columns res_columns; res_columns.emplace_back(std::move(col_disk_name)); res_columns.emplace_back(std::move(col_base_path)); res_columns.emplace_back(std::move(col_cache_base_path)); res_columns.emplace_back(std::move(col_local_path)); res_columns.emplace_back(std::move(col_remote_path)); res_columns.emplace_back(std::move(col_size)); res_columns.emplace_back(std::move(col_refcount)); res_columns.emplace_back(std::move(col_namespace)); res_columns.emplace_back(std::move(col_cache_paths)); UInt64 num_rows = res_columns.at(0)->size(); Chunk chunk(std::move(res_columns), num_rows); return Pipe(std::make_shared(storage_snapshot->metadata->getSampleBlock(), std::move(chunk))); } }