Summary: Example output: {"time_micros": 1431463794310521, "job": 353, "event": "table_file_creation", "file_number": 387, "file_size": 86937, "table_info": {"data_size": "81801", "index_size": "9751", "filter_size": "0", "raw_key_size": "23448", "raw_average_key_size": "24.000000", "raw_value_size": "990571", "raw_average_value_size": "1013.890481", "num_data_blocks": "245", "num_entries": "977", "filter_policy_name": "", "kDeletedKeys": "0"}} Also fixed a bug where BuildTable() in recovery was passing Env::IOHigh argument into paranoid_checks_file parameter. Test Plan: make check + check out the output in the log Reviewers: sdong, rven, yhchiang Reviewed By: yhchiang Subscribers: dhruba, leveldb Differential Revision: https://reviews.facebook.net/D38343main
parent
b5881762bc
commit
dbd95b7532
@ -0,0 +1,46 @@ |
||||
// Copyright (c) 2013, Facebook, Inc. All rights reserved.
|
||||
// This source code is licensed under the BSD-style license found in the
|
||||
// LICENSE file in the root directory of this source tree. An additional grant
|
||||
// of patent rights can be found in the PATENTS file in the same directory.
|
||||
|
||||
#include "db/event_logger_helpers.h" |
||||
|
||||
namespace rocksdb { |
||||
|
||||
namespace { |
||||
inline double SafeDivide(double a, double b) { return b == 0.0 ? 0 : a / b; } |
||||
} // namespace
|
||||
|
||||
void EventLoggerHelpers::LogTableFileCreation( |
||||
EventLogger* event_logger, int job_id, uint64_t file_number, |
||||
uint64_t file_size, const TableProperties& table_properties) { |
||||
auto stream = event_logger->Log(); |
||||
stream << "job" << job_id << "event" |
||||
<< "table_file_creation" |
||||
<< "file_number" << file_number << "file_size" << file_size |
||||
<< "table_properties"; |
||||
stream.StartObject(); |
||||
|
||||
// basic properties:
|
||||
stream << "data_size" << table_properties.data_size |
||||
<< "index_size" << table_properties.index_size |
||||
<< "filter_size" << table_properties.filter_size |
||||
<< "raw_key_size" << table_properties.raw_key_size |
||||
<< "raw_average_key_size" << SafeDivide(table_properties.raw_key_size, |
||||
table_properties.num_entries) |
||||
<< "raw_value_size" << table_properties.raw_value_size |
||||
<< "raw_average_value_size" << SafeDivide( |
||||
table_properties.raw_value_size, table_properties.num_entries) |
||||
<< "num_data_blocks" << table_properties.num_data_blocks |
||||
<< "num_entries" << table_properties.num_entries |
||||
<< "filter_policy_name" << table_properties.filter_policy_name; |
||||
|
||||
// user collected properties
|
||||
for (const auto& prop : table_properties.user_collected_properties) { |
||||
stream << prop.first << prop.second; |
||||
} |
||||
|
||||
stream.EndObject(); |
||||
} |
||||
|
||||
} // namespace rocksdb
|
@ -0,0 +1,18 @@ |
||||
// Copyright (c) 2013, Facebook, Inc. All rights reserved.
|
||||
// This source code is licensed under the BSD-style license found in the
|
||||
// LICENSE file in the root directory of this source tree. An additional grant
|
||||
// of patent rights can be found in the PATENTS file in the same directory.
|
||||
#pragma once |
||||
|
||||
#include "util/event_logger.h" |
||||
#include "rocksdb/table_properties.h" |
||||
|
||||
namespace rocksdb { |
||||
|
||||
class EventLoggerHelpers { |
||||
public: |
||||
static void LogTableFileCreation(EventLogger* event_logger, int job_id, |
||||
uint64_t file_number, uint64_t file_size, |
||||
const TableProperties& table_properties); |
||||
}; |
||||
} // namespace rocksdb
|
Loading…
Reference in new issue