#include "StorageSystemFilesystemCache.h" #include #include #include #include #include #include #include #include namespace DB { NamesAndTypesList StorageSystemFilesystemCache::getNamesAndTypes() { return { {"cache_name", std::make_shared()}, {"cache_base_path", std::make_shared()}, {"cache_path", std::make_shared()}, {"key", std::make_shared()}, {"file_segment_range_begin", std::make_shared()}, {"file_segment_range_end", std::make_shared()}, {"size", std::make_shared()}, {"state", std::make_shared()}, {"cache_hits", std::make_shared()}, {"references", std::make_shared()}, {"downloaded_size", std::make_shared()}, {"kind", std::make_shared()}, {"unbound", std::make_shared>()}, }; } StorageSystemFilesystemCache::StorageSystemFilesystemCache(const StorageID & table_id_) : IStorageSystemOneBlock(table_id_) { } void StorageSystemFilesystemCache::fillData(MutableColumns & res_columns, ContextPtr, const SelectQueryInfo &) const { auto caches = FileCacheFactory::instance().getAll(); for (const auto & [cache_name, cache_data] : caches) { const auto & cache = cache_data->cache; auto file_segments = cache->getSnapshot(); for (const auto & file_segment : *file_segments) { size_t i = 0; res_columns[i++]->insert(cache_name); res_columns[i++]->insert(cache->getBasePath()); /// Do not use `file_segment->getPathInLocalCache` here because it will lead to nullptr dereference /// (because file_segments in getSnapshot doesn't have `cache` field set) res_columns[i++]->insert(cache->getPathInLocalCache(file_segment->key(), file_segment->offset(), file_segment->getKind())); res_columns[i++]->insert(file_segment->key().toString()); const auto & range = file_segment->range(); res_columns[i++]->insert(range.left); res_columns[i++]->insert(range.right); res_columns[i++]->insert(range.size()); res_columns[i++]->insert(FileSegment::stateToString(file_segment->state())); res_columns[i++]->insert(file_segment->getHitsCount()); res_columns[i++]->insert(file_segment->getRefCount()); res_columns[i++]->insert(file_segment->getDownloadedSize(false)); res_columns[i++]->insert(toString(file_segment->getKind())); res_columns[i++]->insert(file_segment->isUnbound()); } } } }