Fix write-ahead log file size overflow (#7870)
Summary: The WAL's file size is stored as an unsigned 64 bit integer. In db_info_dumper.cc, this integer gets converted to a string. Since 2^64 is approximately 10^19, we need 20 digits to represent the integer correctly. To store the decimal representation, we need 21 bytes (+1 due to the '\0' terminator at the end). The code previously used 16 bytes, which would overflow if the log is really big (>1 petabyte). Pull Request resolved: https://github.com/facebook/rocksdb/pull/7870 Reviewed By: ajkr Differential Revision: D25938776 Pulled By: jay-zhuang fbshipit-source-id: 6ee9e21ebd65d297ea90fa1e7e74f3e1c533299d
This commit is contained in:
parent
5b748b9e68
commit
4db58bcfb2
@ -64,9 +64,10 @@ void DumpDBFileSummary(const ImmutableDBOptions& options,
|
|||||||
break;
|
break;
|
||||||
case kWalFile:
|
case kWalFile:
|
||||||
if (env->GetFileSize(dbname + "/" + file, &file_size).ok()) {
|
if (env->GetFileSize(dbname + "/" + file, &file_size).ok()) {
|
||||||
char str[16];
|
wal_info.append(file)
|
||||||
snprintf(str, sizeof(str), "%" PRIu64, file_size);
|
.append(" size: ")
|
||||||
wal_info.append(file).append(" size: ").append(str).append(" ; ");
|
.append(std::to_string(file_size))
|
||||||
|
.append(" ; ");
|
||||||
} else {
|
} else {
|
||||||
Error(options.info_log, "Error when reading LOG file: %s/%s\n",
|
Error(options.info_log, "Error when reading LOG file: %s/%s\n",
|
||||||
dbname.c_str(), file.c_str());
|
dbname.c_str(), file.c_str());
|
||||||
@ -120,9 +121,10 @@ void DumpDBFileSummary(const ImmutableDBOptions& options,
|
|||||||
if (ParseFileName(file, &number, &type)) {
|
if (ParseFileName(file, &number, &type)) {
|
||||||
if (type == kWalFile) {
|
if (type == kWalFile) {
|
||||||
if (env->GetFileSize(options.wal_dir + "/" + file, &file_size).ok()) {
|
if (env->GetFileSize(options.wal_dir + "/" + file, &file_size).ok()) {
|
||||||
char str[16];
|
wal_info.append(file)
|
||||||
snprintf(str, sizeof(str), "%" PRIu64, file_size);
|
.append(" size: ")
|
||||||
wal_info.append(file).append(" size: ").append(str).append(" ; ");
|
.append(std::to_string(file_size))
|
||||||
|
.append(" ; ");
|
||||||
} else {
|
} else {
|
||||||
Error(options.info_log, "Error when reading LOG file %s/%s\n",
|
Error(options.info_log, "Error when reading LOG file %s/%s\n",
|
||||||
options.wal_dir.c_str(), file.c_str());
|
options.wal_dir.c_str(), file.c_str());
|
||||||
|
Loading…
Reference in New Issue
Block a user