Add counter in perf_context to time cipher time (#6596)
Summary: Add `encrypt_data_time` and `decrypt_data_time` perf_context counters to time encryption/decryption time when `EnvEncryption` is enabled. Pull Request resolved: https://github.com/facebook/rocksdb/pull/6596 Test Plan: CI Reviewed By: anand1976 Differential Revision: D20678617 fbshipit-source-id: 7b57536143aa38509cde011f704de33382169e07
This commit is contained in:
parent
03a781a90c
commit
2b02ea25e2
62
env/env_encryption.cc
vendored
62
env/env_encryption.cc
vendored
@ -5,12 +5,14 @@
|
||||
|
||||
#ifndef ROCKSDB_LITE
|
||||
|
||||
#include "rocksdb/env_encryption.h"
|
||||
|
||||
#include <algorithm>
|
||||
#include <cassert>
|
||||
#include <cctype>
|
||||
#include <iostream>
|
||||
|
||||
#include "rocksdb/env_encryption.h"
|
||||
#include "monitoring/perf_context_imp.h"
|
||||
#include "util/aligned_buffer.h"
|
||||
#include "util/coding.h"
|
||||
#include "util/random.h"
|
||||
@ -49,8 +51,12 @@ class EncryptedSequentialFile : public SequentialFile {
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
status = stream_->Decrypt(offset_, (char*)result->data(), result->size());
|
||||
offset_ += result->size(); // We've already ready data from disk, so update offset_ even if decryption fails.
|
||||
{
|
||||
PERF_TIMER_GUARD(decrypt_data_nanos);
|
||||
status = stream_->Decrypt(offset_, (char*)result->data(), result->size());
|
||||
}
|
||||
offset_ += result->size(); // We've already ready data from disk, so update
|
||||
// offset_ even if decryption fails.
|
||||
return status;
|
||||
}
|
||||
|
||||
@ -98,7 +104,10 @@ class EncryptedSequentialFile : public SequentialFile {
|
||||
return status;
|
||||
}
|
||||
offset_ = offset + result->size();
|
||||
status = stream_->Decrypt(offset, (char*)result->data(), result->size());
|
||||
{
|
||||
PERF_TIMER_GUARD(decrypt_data_nanos);
|
||||
status = stream_->Decrypt(offset, (char*)result->data(), result->size());
|
||||
}
|
||||
return status;
|
||||
}
|
||||
};
|
||||
@ -132,7 +141,10 @@ class EncryptedRandomAccessFile : public RandomAccessFile {
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
status = stream_->Decrypt(offset, (char*)result->data(), result->size());
|
||||
{
|
||||
PERF_TIMER_GUARD(decrypt_data_nanos);
|
||||
status = stream_->Decrypt(offset, (char*)result->data(), result->size());
|
||||
}
|
||||
return status;
|
||||
}
|
||||
|
||||
@ -208,7 +220,10 @@ class EncryptedWritableFile : public WritableFileWrapper {
|
||||
// so that the next two lines can be replaced with buf.Append().
|
||||
memmove(buf.BufferStart(), data.data(), data.size());
|
||||
buf.Size(data.size());
|
||||
status = stream_->Encrypt(offset, buf.BufferStart(), buf.CurrentSize());
|
||||
{
|
||||
PERF_TIMER_GUARD(encrypt_data_nanos);
|
||||
status = stream_->Encrypt(offset, buf.BufferStart(), buf.CurrentSize());
|
||||
}
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
@ -232,7 +247,10 @@ class EncryptedWritableFile : public WritableFileWrapper {
|
||||
buf.AllocateNewBuffer(data.size());
|
||||
memmove(buf.BufferStart(), data.data(), data.size());
|
||||
buf.Size(data.size());
|
||||
status = stream_->Encrypt(offset, buf.BufferStart(), buf.CurrentSize());
|
||||
{
|
||||
PERF_TIMER_GUARD(encrypt_data_nanos);
|
||||
status = stream_->Encrypt(offset, buf.BufferStart(), buf.CurrentSize());
|
||||
}
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
@ -337,7 +355,10 @@ class EncryptedRandomRWFile : public RandomRWFile {
|
||||
buf.AllocateNewBuffer(data.size());
|
||||
memmove(buf.BufferStart(), data.data(), data.size());
|
||||
buf.Size(data.size());
|
||||
status = stream_->Encrypt(offset, buf.BufferStart(), buf.CurrentSize());
|
||||
{
|
||||
PERF_TIMER_GUARD(encrypt_data_nanos);
|
||||
status = stream_->Encrypt(offset, buf.BufferStart(), buf.CurrentSize());
|
||||
}
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
@ -358,7 +379,10 @@ class EncryptedRandomRWFile : public RandomRWFile {
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
status = stream_->Decrypt(offset, (char*)result->data(), result->size());
|
||||
{
|
||||
PERF_TIMER_GUARD(decrypt_data_nanos);
|
||||
status = stream_->Decrypt(offset, (char*)result->data(), result->size());
|
||||
}
|
||||
return status;
|
||||
}
|
||||
|
||||
@ -873,9 +897,15 @@ Status CTREncryptionProvider::CreateNewPrefix(const std::string& /*fname*/,
|
||||
// Now populate the rest of the prefix, starting from the third block.
|
||||
PopulateSecretPrefixPart(prefix + (2 * blockSize), prefixLength - (2 * blockSize), blockSize);
|
||||
|
||||
// Encrypt the prefix, starting from block 2 (leave block 0, 1 with initial counter & IV unencrypted)
|
||||
// Encrypt the prefix, starting from block 2 (leave block 0, 1 with initial
|
||||
// counter & IV unencrypted)
|
||||
CTRCipherStream cipherStream(cipher_, prefixIV.data(), initialCounter);
|
||||
auto status = cipherStream.Encrypt(0, prefix + (2 * blockSize), prefixLength - (2 * blockSize));
|
||||
Status status;
|
||||
{
|
||||
PERF_TIMER_GUARD(encrypt_data_nanos);
|
||||
status = cipherStream.Encrypt(0, prefix + (2 * blockSize),
|
||||
prefixLength - (2 * blockSize));
|
||||
}
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
@ -910,9 +940,15 @@ Status CTREncryptionProvider::CreateCipherStream(
|
||||
": read attempt would read beyond file bounds");
|
||||
}
|
||||
|
||||
// Decrypt the encrypted part of the prefix, starting from block 2 (block 0, 1 with initial counter & IV are unencrypted)
|
||||
// Decrypt the encrypted part of the prefix, starting from block 2 (block 0, 1
|
||||
// with initial counter & IV are unencrypted)
|
||||
CTRCipherStream cipherStream(cipher_, iv.data(), initialCounter);
|
||||
auto status = cipherStream.Decrypt(0, (char*)prefix.data() + (2 * blockSize), prefix.size() - (2 * blockSize));
|
||||
Status status;
|
||||
{
|
||||
PERF_TIMER_GUARD(decrypt_data_nanos);
|
||||
status = cipherStream.Decrypt(0, (char*)prefix.data() + (2 * blockSize),
|
||||
prefix.size() - (2 * blockSize));
|
||||
}
|
||||
if (!status.ok()) {
|
||||
return status;
|
||||
}
|
||||
|
@ -221,6 +221,11 @@ struct PerfContext {
|
||||
uint64_t iter_prev_cpu_nanos;
|
||||
uint64_t iter_seek_cpu_nanos;
|
||||
|
||||
// Time spent in encrypting data. Populated when EncryptedEnv is used.
|
||||
uint64_t encrypt_data_nanos;
|
||||
// Time spent in decrypting data. Populated when EncryptedEnv is used.
|
||||
uint64_t decrypt_data_nanos;
|
||||
|
||||
std::map<uint32_t, PerfContextByLevel>* level_to_perf_context = nullptr;
|
||||
bool per_level_perf_context_enabled = false;
|
||||
};
|
||||
|
Loading…
x
Reference in New Issue
Block a user