2017-09-01 22:47:17 +08:00
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <memory>
|
2017-08-24 22:50:18 +08:00
|
|
|
|
2017-09-01 22:47:17 +08:00
|
|
|
#include "reactors_distributed.hpp"
|
2017-08-25 21:25:49 +08:00
|
|
|
#include "memgraph_config.hpp"
|
|
|
|
#include "memgraph_distributed.hpp"
|
|
|
|
#include "memgraph_transactions.hpp"
|
2017-08-24 22:50:18 +08:00
|
|
|
|
2017-09-01 22:47:17 +08:00
|
|
|
/**
|
|
|
|
* List of queries that should be executed.
|
|
|
|
*/
|
|
|
|
std::vector<std::string> queries = {{
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"vertex count",
|
|
|
|
"create vertex",
|
|
|
|
"create vertex",
|
|
|
|
"vertex count"
|
|
|
|
}};
|
2017-08-24 22:50:18 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This is the client that issues some hard-coded queries.
|
|
|
|
*/
|
|
|
|
class Client : public Reactor {
|
|
|
|
public:
|
|
|
|
Client(std::string name) : Reactor(name) {
|
|
|
|
}
|
|
|
|
|
2017-08-25 21:25:49 +08:00
|
|
|
void IssueQueries(std::shared_ptr<ChannelWriter> channel_to_leader) {
|
|
|
|
// (concurrently) create a couple of vertices
|
2017-09-01 22:47:17 +08:00
|
|
|
for (int query_idx = 0; query_idx < queries.size(); ++query_idx) {
|
2017-08-25 21:25:49 +08:00
|
|
|
// register callback
|
2017-09-01 22:47:17 +08:00
|
|
|
std::string channel_name = "query-" + std::to_string(query_idx);
|
2017-08-25 21:25:49 +08:00
|
|
|
auto stream = Open(channel_name).first;
|
|
|
|
stream
|
|
|
|
->OnEventOnce()
|
2017-09-01 22:47:17 +08:00
|
|
|
.ChainOnce<ResultMsg>([this, query_idx](const ResultMsg &msg,
|
|
|
|
const Subscription &sub){
|
|
|
|
std::cout << "Result of query " << query_idx << " ("
|
|
|
|
<< queries[query_idx] << "):" << std::endl
|
|
|
|
<< " " << msg.result() << std::endl;
|
|
|
|
sub.CloseChannel();
|
|
|
|
});
|
2017-08-25 21:25:49 +08:00
|
|
|
|
|
|
|
// then issue the query (to avoid race conditions)
|
2017-09-01 22:47:17 +08:00
|
|
|
std::cout << "Issuing command " << query_idx << " ("
|
|
|
|
<< queries[query_idx] << ")" << std::endl;
|
|
|
|
channel_to_leader->Send<QueryMsg>(channel_name, queries[query_idx]);
|
2017-08-25 21:25:49 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-24 22:50:18 +08:00
|
|
|
virtual void Run() {
|
2017-08-25 21:25:49 +08:00
|
|
|
MemgraphDistributed& memgraph = MemgraphDistributed::GetInstance();
|
2017-09-01 22:47:17 +08:00
|
|
|
auto mnid = memgraph.LeaderMnid();
|
2017-08-24 22:50:18 +08:00
|
|
|
|
2017-08-25 21:25:49 +08:00
|
|
|
memgraph.FindChannel(mnid, "master", "client-queries")
|
|
|
|
->OnEventOnce()
|
|
|
|
.ChainOnce<ChannelResolvedMessage>([this](const ChannelResolvedMessage &msg, const Subscription& sub) {
|
|
|
|
sub.CloseChannel();
|
|
|
|
IssueQueries(msg.channelWriter());
|
|
|
|
});
|
2017-08-24 22:50:18 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
2017-08-25 21:25:49 +08:00
|
|
|
google::InitGoogleLogging(argv[0]);
|
2017-08-24 22:50:18 +08:00
|
|
|
|
|
|
|
System &system = System::GetInstance();
|
|
|
|
Distributed &distributed = Distributed::GetInstance();
|
|
|
|
MemgraphDistributed& memgraph = MemgraphDistributed::GetInstance();
|
|
|
|
memgraph.RegisterConfig(ParseConfig());
|
|
|
|
distributed.StartServices();
|
|
|
|
|
|
|
|
system.Spawn<Client>("client");
|
|
|
|
|
|
|
|
system.AwaitShutdown();
|
|
|
|
distributed.StopServices();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|