2018-10-10 16:23:10 +08:00
|
|
|
#include "interactive_planning.hpp"
|
|
|
|
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
|
|
|
|
#include "database/distributed/distributed_graph_db.hpp"
|
|
|
|
#include "database/distributed/graph_db_accessor.hpp"
|
|
|
|
#include "query/plan/distributed.hpp"
|
|
|
|
#include "query/plan/distributed_pretty_print.hpp"
|
|
|
|
|
|
|
|
DECLARE_int32(min_log_level);
|
|
|
|
|
|
|
|
DEFCOMMAND(ShowDistributed) {
|
|
|
|
int64_t plan_ix = 0;
|
|
|
|
std::stringstream ss(args[0]);
|
|
|
|
ss >> plan_ix;
|
|
|
|
if (ss.fail() || !ss.eof() || plan_ix >= plans.size()) return;
|
2019-02-05 23:12:02 +08:00
|
|
|
const auto &plan = plans[plan_ix].final_plan;
|
2018-10-10 16:23:10 +08:00
|
|
|
std::atomic<int64_t> plan_id{0};
|
Remove GraphDbAccessor and storage types from Ast
Summary:
This diff removes the need for a database when parsing a query and
creating an Ast. Instead of storing storage::{Label,Property,EdgeType}
in Ast nodes, we store the name and an index into all of the names. This
allows for easy creation of a map from {Label,Property,EdgeType} index
into the concrete storage type. Obviously, this comes with a performance
penalty during execution, but it should be minor. The upside is that the
query/frontend minimally depends on storage (PropertyValue), which makes
writing tests easier as well as running them a lot faster (there is no
database setup). This is most noticeable in the ast_serialization test
which took a long time due to start up of a distributed database.
Reviewers: mtomic, llugovic
Reviewed By: mtomic
Subscribers: mferencevic, pullbot
Differential Revision: https://phabricator.memgraph.io/D1774
2019-01-14 21:41:37 +08:00
|
|
|
std::vector<storage::Property> properties_by_ix =
|
|
|
|
query::NamesToProperties(ast_storage.properties_, &dba);
|
|
|
|
auto distributed_plan = MakeDistributedPlan(ast_storage, *plan, symbol_table,
|
|
|
|
plan_id, properties_by_ix);
|
2018-10-10 16:23:10 +08:00
|
|
|
{
|
|
|
|
std::cout << "---- Master Plan ---- " << std::endl;
|
|
|
|
query::plan::DistributedPrettyPrint(dba,
|
|
|
|
distributed_plan.master_plan.get());
|
|
|
|
std::cout << std::endl;
|
|
|
|
}
|
|
|
|
for (size_t i = 0; i < distributed_plan.worker_plans.size(); ++i) {
|
|
|
|
int64_t id;
|
|
|
|
std::shared_ptr<query::plan::LogicalOperator> worker_plan;
|
|
|
|
std::tie(id, worker_plan) = distributed_plan.worker_plans[i];
|
|
|
|
std::cout << "---- Worker Plan #" << id << " ---- " << std::endl;
|
|
|
|
query::plan::DistributedPrettyPrint(dba, worker_plan.get());
|
|
|
|
std::cout << std::endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
|
|
|
FLAGS_min_log_level = google::ERROR;
|
|
|
|
google::InitGoogleLogging(argv[0]);
|
|
|
|
AddCommand("show-distributed",
|
|
|
|
{ShowDistributedCommand, 1,
|
|
|
|
"Show the Nth plan as for distributed execution"});
|
|
|
|
database::Master db;
|
2018-10-16 16:58:41 +08:00
|
|
|
db.Start();
|
2018-10-10 16:23:10 +08:00
|
|
|
auto dba = db.Access();
|
|
|
|
RunInteractivePlanning(dba.get());
|
|
|
|
db.Shutdown();
|
|
|
|
db.AwaitShutdown();
|
|
|
|
return 0;
|
|
|
|
}
|