From 63586f274036c6127c033c2b0b61fd5e6596baaa Mon Sep 17 00:00:00 2001 From: yiwu-arbug Date: Fri, 17 Apr 2020 12:32:44 -0700 Subject: [PATCH] Fix NewRandomRWFile and ReuseWritableFile in KeyManagedEncryptedEnv (#167) Summary: Fix NewRandomRWFile and ReuseWritableFile misuse of `GetFile()` and `NewFile()`. See inline comments. Test Plan: manual test with tikv Signed-off-by: Yi Wu Signed-off-by: tabokie --- encryption/encryption.cc | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/encryption/encryption.cc b/encryption/encryption.cc index cdb0d3a61cd..46e96ec5526 100644 --- a/encryption/encryption.cc +++ b/encryption/encryption.cc @@ -358,7 +358,10 @@ Status KeyManagedEncryptedEnv::ReuseWritableFile( const std::string& fname, const std::string& old_fname, std::unique_ptr* result, const EnvOptions& options) { FileEncryptionInfo file_info; - Status s = key_manager_->GetFile(fname, &file_info); + // ReuseWritableFile is only used in the context of rotating WAL file and + // reuse them. Old content is discardable and new WAL records are to + // overwrite the file. So NewFile() should be called. + Status s = key_manager_->NewFile(fname, &file_info); if (!s.ok()) { return s; } @@ -386,7 +389,10 @@ Status KeyManagedEncryptedEnv::NewRandomRWFile( const std::string& fname, std::unique_ptr* result, const EnvOptions& options) { FileEncryptionInfo file_info; - Status s = key_manager_->NewFile(fname, &file_info); + // NewRandomRWFile is only used in the context of external file ingestion, + // for rewriting global seqno. So it should call GetFile() instead of + // NewFile(). + Status s = key_manager_->GetFile(fname, &file_info); if (!s.ok()) { return s; }