// Copyright (c) 2017-present, Facebook, Inc. All rights reserved. // This source code is licensed under both the GPLv2 (found in the // COPYING file in the root directory) and Apache 2.0 License // (found in the LICENSE.Apache file in the root directory). #include "env/composite_env_wrapper.h" #include "monitoring/perf_context_imp.h" #include "rocksdb/env.h" #include "rocksdb/file_system.h" #include "rocksdb/status.h" namespace ROCKSDB_NAMESPACE { #ifndef ROCKSDB_LITE namespace { class TimedFileSystem : public FileSystemWrapper { public: explicit TimedFileSystem(const std::shared_ptr& base) : FileSystemWrapper(base) {} const char* Name() const override { return "TimedFS"; } IOStatus NewSequentialFile(const std::string& fname, const FileOptions& options, std::unique_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_new_sequential_file_nanos); return FileSystemWrapper::NewSequentialFile(fname, options, result, dbg); } IOStatus NewRandomAccessFile(const std::string& fname, const FileOptions& options, std::unique_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_new_random_access_file_nanos); return FileSystemWrapper::NewRandomAccessFile(fname, options, result, dbg); } IOStatus NewWritableFile(const std::string& fname, const FileOptions& options, std::unique_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_new_writable_file_nanos); return FileSystemWrapper::NewWritableFile(fname, options, result, dbg); } IOStatus ReuseWritableFile(const std::string& fname, const std::string& old_fname, const FileOptions& options, std::unique_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_reuse_writable_file_nanos); return FileSystemWrapper::ReuseWritableFile(fname, old_fname, options, result, dbg); } IOStatus NewRandomRWFile(const std::string& fname, const FileOptions& options, std::unique_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_new_random_rw_file_nanos); return FileSystemWrapper::NewRandomRWFile(fname, options, result, dbg); } IOStatus NewDirectory(const std::string& name, const IOOptions& options, std::unique_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_new_directory_nanos); return FileSystemWrapper::NewDirectory(name, options, result, dbg); } IOStatus FileExists(const std::string& fname, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_file_exists_nanos); return FileSystemWrapper::FileExists(fname, options, dbg); } IOStatus GetChildren(const std::string& dir, const IOOptions& options, std::vector* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_get_children_nanos); return FileSystemWrapper::GetChildren(dir, options, result, dbg); } IOStatus GetChildrenFileAttributes(const std::string& dir, const IOOptions& options, std::vector* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_get_children_file_attributes_nanos); return FileSystemWrapper::GetChildrenFileAttributes(dir, options, result, dbg); } IOStatus DeleteFile(const std::string& fname, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_delete_file_nanos); return FileSystemWrapper::DeleteFile(fname, options, dbg); } IOStatus CreateDir(const std::string& dirname, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_create_dir_nanos); return FileSystemWrapper::CreateDir(dirname, options, dbg); } IOStatus CreateDirIfMissing(const std::string& dirname, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_create_dir_if_missing_nanos); return FileSystemWrapper::CreateDirIfMissing(dirname, options, dbg); } IOStatus DeleteDir(const std::string& dirname, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_delete_dir_nanos); return FileSystemWrapper::DeleteDir(dirname, options, dbg); } IOStatus GetFileSize(const std::string& fname, const IOOptions& options, uint64_t* file_size, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_get_file_size_nanos); return FileSystemWrapper::GetFileSize(fname, options, file_size, dbg); } IOStatus GetFileModificationTime(const std::string& fname, const IOOptions& options, uint64_t* file_mtime, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_get_file_modification_time_nanos); return FileSystemWrapper::GetFileModificationTime(fname, options, file_mtime, dbg); } IOStatus RenameFile(const std::string& src, const std::string& dst, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_rename_file_nanos); return FileSystemWrapper::RenameFile(src, dst, options, dbg); } IOStatus LinkFile(const std::string& src, const std::string& dst, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_link_file_nanos); return FileSystemWrapper::LinkFile(src, dst, options, dbg); } IOStatus LockFile(const std::string& fname, const IOOptions& options, FileLock** lock, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_lock_file_nanos); return FileSystemWrapper::LockFile(fname, options, lock, dbg); } IOStatus UnlockFile(FileLock* lock, const IOOptions& options, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_unlock_file_nanos); return FileSystemWrapper::UnlockFile(lock, options, dbg); } IOStatus NewLogger(const std::string& fname, const IOOptions& options, std::shared_ptr* result, IODebugContext* dbg) override { PERF_TIMER_GUARD(env_new_logger_nanos); return FileSystemWrapper::NewLogger(fname, options, result, dbg); } }; } // namespace std::shared_ptr NewTimedFileSystem( const std::shared_ptr& base) { return std::make_shared(base); } // An environment that measures function call times for filesystem // operations, reporting results to variables in PerfContext. Env* NewTimedEnv(Env* base_env) { std::shared_ptr timed_fs = NewTimedFileSystem(base_env->GetFileSystem()); return new CompositeEnvWrapper(base_env, timed_fs); } #else // ROCKSDB_LITE Env* NewTimedEnv(Env* /*base_env*/) { return nullptr; } #endif // !ROCKSDB_LITE } // namespace ROCKSDB_NAMESPACE