98ac6b646a
Summary: Implement a parsing tool io_tracer_parser that takes IO trace file (binary file) with command line argument --io_trace_file and output file with --output_file and dumps the IO trace records in outputfile in human readable form. Also added unit test cases that generates IO trace records and calls io_tracer_parse to parse those records. Pull Request resolved: https://github.com/facebook/rocksdb/pull/7333 Test Plan: make check -j64, Add unit test cases. Reviewed By: anand1976 Differential Revision: D23772360 Pulled By: akankshamahajan15 fbshipit-source-id: 9c20519c189362e6663352d08863326f3e496271
41 lines
1.2 KiB
C++
41 lines
1.2 KiB
C++
// Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
|
|
// This source code is licensed under both the GPLv2 (found in the
|
|
// COPYING file in the root directory) and Apache 2.0 License
|
|
// (found in the LICENSE.Apache file in the root directory).
|
|
|
|
#ifndef ROCKSDB_LITE
|
|
#pragma once
|
|
|
|
#include <memory>
|
|
|
|
#include "rocksdb/env.h"
|
|
#include "rocksdb/status.h"
|
|
|
|
namespace ROCKSDB_NAMESPACE {
|
|
|
|
struct IOTraceHeader;
|
|
struct IOTraceRecord;
|
|
|
|
// IOTraceRecordParser class reads the IO trace file (in binary format) and
|
|
// dumps the human readable records in output_file_.
|
|
class IOTraceRecordParser {
|
|
public:
|
|
explicit IOTraceRecordParser(const std::string& input_file);
|
|
|
|
// ReadIOTraceRecords reads the binary trace file records one by one and
|
|
// invoke PrintHumanReadableIOTraceRecord to dump the records in output_file_.
|
|
int ReadIOTraceRecords();
|
|
|
|
private:
|
|
void PrintHumanReadableHeader(const IOTraceHeader& header);
|
|
void PrintHumanReadableIOTraceRecord(const IOTraceRecord& record);
|
|
|
|
// Binary file that contains IO trace records.
|
|
std::string input_file_;
|
|
};
|
|
|
|
int io_tracer_parser(int argc, char** argv);
|
|
|
|
} // namespace ROCKSDB_NAMESPACE
|
|
#endif // ROCKSDB_LITE
|