Header logger should call LogHeader() (#4980)

Summary:
The info log header feature never worked well, because log level Header was not
translated to Logger::LogHeader() call. Fix it.
Pull Request resolved: https://github.com/facebook/rocksdb/pull/4980

Differential Revision: D14087283

Pulled By: siying

fbshipit-source-id: 7e7d03ce35fa8d13d4ee549f46f7326f7bc0006d
main
Siying Dong 6 years ago committed by Facebook Github Bot
parent 26a33ee5bd
commit c2affccc18
  1. 3
      db/db_impl_open.cc
  2. 2
      env/env.cc
  3. 3
      java/src/test/java/org/rocksdb/InfoLogLevelTest.java

@ -1316,7 +1316,8 @@ Status DBImpl::Open(const DBOptions& db_options, const std::string& dbname,
#endif // !ROCKSDB_LITE #endif // !ROCKSDB_LITE
if (s.ok()) { if (s.ok()) {
ROCKS_LOG_INFO(impl->immutable_db_options_.info_log, "DB pointer %p", impl); ROCKS_LOG_HEADER(impl->immutable_db_options_.info_log, "DB pointer %p",
impl);
LogFlush(impl->immutable_db_options_.info_log); LogFlush(impl->immutable_db_options_.info_log);
assert(impl->TEST_WALBufferIsEmpty()); assert(impl->TEST_WALBufferIsEmpty());
// If the assert above fails then we need to FlushWAL before returning // If the assert above fails then we need to FlushWAL before returning

2
env/env.cc vendored

@ -138,6 +138,8 @@ void Logger::Logv(const InfoLogLevel log_level, const char* format, va_list ap)
// are INFO level. We don't want to add extra costs to those existing // are INFO level. We don't want to add extra costs to those existing
// logging. // logging.
Logv(format, ap); Logv(format, ap);
} else if (log_level == InfoLogLevel::HEADER_LEVEL) {
LogHeader(format, ap);
} else { } else {
char new_format[500]; char new_format[500];
snprintf(new_format, sizeof(new_format) - 1, "[%s] %s", snprintf(new_format, sizeof(new_format) - 1, "[%s] %s",

@ -27,6 +27,7 @@ public class InfoLogLevelTest {
try (final RocksDB db = try (final RocksDB db =
RocksDB.open(dbFolder.getRoot().getAbsolutePath())) { RocksDB.open(dbFolder.getRoot().getAbsolutePath())) {
db.put("key".getBytes(), "value".getBytes()); db.put("key".getBytes(), "value".getBytes());
db.flush(new FlushOptions().setWaitForFlush(true));
assertThat(getLogContentsWithoutHeader()).isNotEmpty(); assertThat(getLogContentsWithoutHeader()).isNotEmpty();
} }
} }
@ -93,7 +94,7 @@ public class InfoLogLevelTest {
int first_non_header = lines.length; int first_non_header = lines.length;
// Identify the last line of the header // Identify the last line of the header
for (int i = lines.length - 1; i >= 0; --i) { for (int i = lines.length - 1; i >= 0; --i) {
if (lines[i].indexOf("Options.") >= 0 && lines[i].indexOf(':') >= 0) { if (lines[i].indexOf("DB pointer") >= 0) {
first_non_header = i + 1; first_non_header = i + 1;
break; break;
} }

Loading…
Cancel
Save