95f1b6fe56
Summary: Ensures that query plans are invalidated on the remote only when it's guaranteed they will never be used on the master. This is done by invalidating remote caches in the `CachedPlan` destructor. There are two unplesant side-effects. First, an RPC call is made in an object destructor. This is somewhat ugly, but not that different then making an RPC call that must succeed in any other function. Note that this does NOT slow down any query execution because the relevant destructor is called by the skiplist garbage collector. The second ugly side-effect is that in the unit test now we need to sleep to ensure the skiplist GC destructs a cached plan before checking that it's invalidated on the remote worker. We might want to redesign this at some point. Reviewers: teon.banek Reviewed By: teon.banek Subscribers: pullbot Differential Revision: https://phabricator.memgraph.io/D1302 |
||
---|---|---|
.. | ||
antlr_parser.cpp | ||
antlr_sigsegv.cpp | ||
antlr_tree_pretty_print.cpp | ||
binomial.cpp | ||
bolt_client.cpp | ||
card_fraud_generate_snapshot.cpp | ||
card_fraud_local.cpp | ||
CMakeLists.txt | ||
distributed_common.hpp | ||
distributed_repl.cpp | ||
endinan.cpp | ||
generate_snapshot.cpp | ||
query_hash.cpp | ||
query_planner.cpp | ||
raft_rpc.cpp | ||
repl.cpp | ||
single_query.cpp | ||
sl_position_and_count.cpp | ||
stripped_timing.cpp | ||
test_antlr_sigsegv | ||
xorshift.cpp |