6525451489
Summary: Start removing `is_remote` from `Address` Remove `GlobalAddress` Remove `GlobalizedAddress` Remove bitmasks from `Address` Remove `is_local` from `Address` Remove `is_local` from `RecordAccessor` Remove `worker_id` from `Address` Remove `worker_id` from `GidGenerator` Unfriend `IndexRpcServer` from `Storage` Remove `LocalizedAddressIfPossible` Make member private Remove `worker_id` from `Storage` Copy function to ease removal of distributed logic Remove `worker_id` from `WriteAheadLog` Remove `worker_id` from `GraphDb` Remove `worker_id` from durability Remove nonexistant function Remove `gid` from `Address` Remove usage of `Address` Remove `Address` Remove `VertexAddress` and `EdgeAddress` Fix Id test Remove `cypher_id` from `VersionList` Remove `cypher_id` from durability Remove `cypher_id` member from `VersionList` Remove `cypher_id` from database Fix recovery (revert D1142) Remove unnecessary functions from `GraphDbAccessor` Revert `InsertEdge` implementation to the way it was in/before D1142 Remove leftover `VertexAddress` from `Edge` Remove `PostCreateIndex` and `PopulateIndexFromBuildIndex` Split durability paths into single node and distributed Fix `TransactionIdFromWalFilename` implementation Fix tests Remove `cypher_id` from `snapshooter` and `durability` test Reviewers: msantl, teon.banek Reviewed By: msantl Subscribers: msantl, pullbot Differential Revision: https://phabricator.memgraph.io/D1647
89 lines
2.9 KiB
C++
89 lines
2.9 KiB
C++
#include <experimental/filesystem>
|
|
#include <iostream>
|
|
#include <limits>
|
|
|
|
#include <gflags/gflags.h>
|
|
#include <glog/logging.h>
|
|
|
|
#include "durability/hashed_file_reader.hpp"
|
|
#include "durability/single_node/recovery.hpp"
|
|
#include "durability/single_node/state_delta.hpp"
|
|
#include "durability/single_node/version.hpp"
|
|
#include "durability/single_node/wal.hpp"
|
|
#include "transactions/type.hpp"
|
|
|
|
DEFINE_string(wal_file, "", "WAL file location");
|
|
|
|
using communication::bolt::Value;
|
|
namespace fs = std::experimental::filesystem;
|
|
|
|
std::string StateDeltaTypeToString(database::StateDelta::Type type) {
|
|
switch (type) {
|
|
case database::StateDelta::Type::TRANSACTION_BEGIN:
|
|
return "TRANSACTION_BEGIN";
|
|
case database::StateDelta::Type::TRANSACTION_COMMIT:
|
|
return "TRANSACTION_COMMIT";
|
|
case database::StateDelta::Type::TRANSACTION_ABORT:
|
|
return "TRANSACTION_ABORT";
|
|
case database::StateDelta::Type::CREATE_VERTEX:
|
|
return "CREATE_VERTEX";
|
|
case database::StateDelta::Type::CREATE_EDGE:
|
|
return "CREATE_EDGE";
|
|
case database::StateDelta::Type::SET_PROPERTY_VERTEX:
|
|
return "SET_PROPERTY_VERTEX";
|
|
case database::StateDelta::Type::SET_PROPERTY_EDGE:
|
|
return "SET_PROPERTY_EDGE";
|
|
case database::StateDelta::Type::ADD_LABEL:
|
|
return "ADD_LABEL";
|
|
case database::StateDelta::Type::REMOVE_LABEL:
|
|
return "REMOVE_LABEL";
|
|
case database::StateDelta::Type::REMOVE_VERTEX:
|
|
return "REMOVE_VERTEX";
|
|
case database::StateDelta::Type::REMOVE_EDGE:
|
|
return "REMOVE_EDGE";
|
|
case database::StateDelta::Type::BUILD_INDEX:
|
|
return "BUILD_INDEX";
|
|
}
|
|
}
|
|
|
|
int main(int argc, char *argv[]) {
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
|
google::InitGoogleLogging(argv[0]);
|
|
|
|
fs::path wal_path(FLAGS_wal_file);
|
|
CHECK(fs::exists(wal_path)) << "File doesn't exist!";
|
|
|
|
HashedFileReader wal_reader;
|
|
CHECK(wal_reader.Open(wal_path)) << "Couldn't open wal file!";
|
|
|
|
communication::bolt::Decoder<HashedFileReader> decoder(wal_reader);
|
|
|
|
auto magic_number = durability::kWalMagic;
|
|
wal_reader.Read(magic_number.data(), magic_number.size());
|
|
CHECK(magic_number == durability::kWalMagic) << "Wal magic number mismatch";
|
|
|
|
communication::bolt::Value dv;
|
|
decoder.ReadValue(&dv);
|
|
CHECK(dv.ValueInt() == durability::kVersion) << "Wal version mismatch";
|
|
|
|
tx::TransactionId max_observed_tx_id{0};
|
|
tx::TransactionId min_observed_tx_id{std::numeric_limits<uint64_t>::max()};
|
|
|
|
std::vector<std::string> wal_entries;
|
|
|
|
while (true) {
|
|
auto delta = database::StateDelta::Decode(wal_reader, decoder);
|
|
if (!delta) break;
|
|
|
|
max_observed_tx_id = std::max(max_observed_tx_id, delta->transaction_id);
|
|
min_observed_tx_id = std::min(min_observed_tx_id, delta->transaction_id);
|
|
LOG(INFO) << "Found tx: " << delta->transaction_id << " "
|
|
<< StateDeltaTypeToString(delta->type);
|
|
}
|
|
|
|
LOG(INFO) << "Min tx " << min_observed_tx_id;
|
|
LOG(INFO) << "Max tx " << max_observed_tx_id;
|
|
|
|
return 0;
|
|
}
|