// Copyright 2021 Memgraph Ltd. // // Use of this software is governed by the Business Source License // included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source // License, and you may not use this file except in compliance with the Business Source License. // // As of the Change Date specified in that file, in accordance with // the Business Source License, use of this software will be governed // by the Apache License, Version 2.0, included in the file // licenses/APL.txt. #include #include #include #include #include "io/network/endpoint.hpp" #include "utils/logging.hpp" #include "utils/string.hpp" DEFINE_string(database_endpoints, "127.0.0.1:7687,127.0.0.1:7688,127.0.0.1:7689", "An array of database endspoints. Each endpoint is separated by " "comma. Within each endpoint, colon separates host and port. Use " "IPv4 addresses as hosts. First endpoint represents main " "replication instance."); DEFINE_string(username, "", "Database username."); DEFINE_string(password, "", "Database password."); DEFINE_bool(use_ssl, false, "Use SSL connection."); DEFINE_int32(nodes, 1000, "Number of nodes in DB."); DEFINE_int32(edges, 5000, "Number of edges in DB."); DEFINE_double(reads_duration_limit, 10.0, "How long should the client perform reads (seconds)"); namespace mg::e2e::replication { auto ParseDatabaseEndpoints(const std::string &database_endpoints_str) { const auto db_endpoints_strs = utils::Split(database_endpoints_str, ","); std::vector database_endpoints; for (const auto &db_endpoint_str : db_endpoints_strs) { const auto maybe_host_port = io::network::Endpoint::ParseSocketOrIpAddress(db_endpoint_str, 7687); MG_ASSERT(maybe_host_port); database_endpoints.emplace_back(io::network::Endpoint(maybe_host_port->first, maybe_host_port->second)); } return database_endpoints; } auto Connect(const io::network::Endpoint &database_endpoint) { mg::Client::Params params; params.host = database_endpoint.address; params.port = database_endpoint.port; params.use_ssl = FLAGS_use_ssl; auto client = mg::Client::Connect(params); if (!client) { LOG_FATAL("Failed to connect!"); } return client; } class IntGenerator { public: IntGenerator(const std::string &purpose, int start, int end) : seed_(std::chrono::high_resolution_clock::now().time_since_epoch().count()), rng_(seed_), dist_(start, end) { spdlog::info("{} int generator seed: {}", purpose, seed_); } int Next() { return dist_(rng_); } private: uint64_t seed_; std::mt19937 rng_; std::uniform_int_distribution dist_; }; } // namespace mg::e2e::replication