#include #include #include #include #include #include #include #include #include #include int mainEntryClickHouseKeeperConverter(int argc, char ** argv) { using namespace DB; namespace po = boost::program_options; po::options_description desc = createOptionsDescription("Allowed options", getTerminalWidth()); desc.add_options() ("help,h", "produce help message") ("zookeeper-logs-dir", po::value(), "Path to directory with ZooKeeper logs") ("zookeeper-snapshots-dir", po::value(), "Path to directory with ZooKeeper snapshots") ("output-dir", po::value(), "Directory to place output clickhouse-keeper snapshot") ; po::variables_map options; po::store(po::command_line_parser(argc, argv).options(desc).run(), options); Poco::AutoPtr console_channel(new Poco::ConsoleChannel); Poco::Logger * logger = &Poco::Logger::get("KeeperConverter"); logger->setChannel(console_channel); if (options.count("help")) { std::cout << "Usage: clickhouse keeper-converter --zookeeper-logs-dir /var/lib/zookeeper/data/version-2 --zookeeper-snapshots-dir /var/lib/zookeeper/data/version-2 --output-dir /var/lib/clickhouse/coordination/snapshots" << std::endl; std::cout << desc << std::endl; return 0; } try { auto keeper_context = std::make_shared(); keeper_context->digest_enabled = true; DB::KeeperStorage storage(/* tick_time_ms */ 500, /* superdigest */ "", keeper_context, /* initialize_system_nodes */ false); DB::deserializeKeeperStorageFromSnapshotsDir(storage, options["zookeeper-snapshots-dir"].as(), logger); storage.initializeSystemNodes(); DB::deserializeLogsAndApplyToStorage(storage, options["zookeeper-logs-dir"].as(), logger); DB::SnapshotMetadataPtr snapshot_meta = std::make_shared(storage.getZXID(), 1, std::make_shared()); DB::KeeperStorageSnapshot snapshot(&storage, snapshot_meta); DB::KeeperSnapshotManager manager(options["output-dir"].as(), 1, keeper_context); auto snp = manager.serializeSnapshotToBuffer(snapshot); auto path = manager.serializeSnapshotBufferToDisk(*snp, storage.getZXID()); std::cout << "Snapshot serialized to path:" << path << std::endl; } catch (...) { std::cerr << getCurrentExceptionMessage(true) << '\n'; return getCurrentExceptionCode(); } return 0; }