// // Created by zzy on 2023/1/5. // #pragma once #include #include #include #include "../coders/protocol_fwd.h" #include "../common_define.h" #include "../utility/lru.h" namespace polarx_rpc { class CrequestCache final { NO_COPY_MOVE(CrequestCache); private: const size_t hash_slots_; std::vector< std::unique_ptr>>> sql_cache_; std::vector>>> plan_cache_; std::hash hasher_; public: CrequestCache(size_t cache_size, size_t hash_slots) : hash_slots_(hash_slots) { sql_cache_.reserve(hash_slots_); plan_cache_.reserve(hash_slots_); auto cache_per_slot = cache_size / hash_slots_; if (cache_per_slot < 1) cache_per_slot = 1; for (size_t i = 0; i < hash_slots; ++i) { sql_cache_.emplace_back( new CcopyableLru>( cache_per_slot)); plan_cache_.emplace_back( new CcopyableLru>( cache_per_slot)); } } std::shared_ptr get_sql(const std::string &key) { auto ptr = sql_cache_[hasher_(key) % hash_slots_]->get(key); if (LIKELY(ptr)) plugin_info.sql_hit.fetch_add(1, std::memory_order_release); else plugin_info.sql_miss.fetch_add(1, std::memory_order_release); return std::move(ptr); } void set_sql(std::string &&key, std::shared_ptr &&val) { auto evicted = sql_cache_[hasher_(key) % hash_slots_]->put( std::forward(key), std::forward>(val)); plugin_info.sql_evict.fetch_add(evicted, std::memory_order_release); } std::shared_ptr get_plan(const std::string &key) { auto ptr = plan_cache_[hasher_(key) % hash_slots_]->get(key); if (LIKELY(ptr)) plugin_info.plan_hit.fetch_add(1, std::memory_order_release); else plugin_info.plan_miss.fetch_add(1, std::memory_order_release); return std::move(ptr); } void set_plan(std::string &&key, std::shared_ptr &&val) { auto evicted = plan_cache_[hasher_(key) % hash_slots_]->put( std::forward(key), std::forward>(val)); plugin_info.plan_evict.fetch_add(evicted, std::memory_order_release); } }; } // namespace polarx_rpc