env_timed.cc 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. // Copyright (c) 2017-present, Facebook, Inc. All rights reserved.
  2. // This source code is licensed under both the GPLv2 (found in the
  3. // COPYING file in the root directory) and Apache 2.0 License
  4. // (found in the LICENSE.Apache file in the root directory).
  5. #include "monitoring/perf_context_imp.h"
  6. #include "rocksdb/env.h"
  7. #include "rocksdb/status.h"
  8. namespace ROCKSDB_NAMESPACE {
  9. #ifndef ROCKSDB_LITE
  10. // An environment that measures function call times for filesystem
  11. // operations, reporting results to variables in PerfContext.
  12. class TimedEnv : public EnvWrapper {
  13. public:
  14. explicit TimedEnv(Env* base_env) : EnvWrapper(base_env) {}
  15. Status NewSequentialFile(const std::string& fname,
  16. std::unique_ptr<SequentialFile>* result,
  17. const EnvOptions& options) override {
  18. PERF_TIMER_GUARD(env_new_sequential_file_nanos);
  19. return EnvWrapper::NewSequentialFile(fname, result, options);
  20. }
  21. Status NewRandomAccessFile(const std::string& fname,
  22. std::unique_ptr<RandomAccessFile>* result,
  23. const EnvOptions& options) override {
  24. PERF_TIMER_GUARD(env_new_random_access_file_nanos);
  25. return EnvWrapper::NewRandomAccessFile(fname, result, options);
  26. }
  27. Status NewWritableFile(const std::string& fname,
  28. std::unique_ptr<WritableFile>* result,
  29. const EnvOptions& options) override {
  30. PERF_TIMER_GUARD(env_new_writable_file_nanos);
  31. return EnvWrapper::NewWritableFile(fname, result, options);
  32. }
  33. Status ReuseWritableFile(const std::string& fname,
  34. const std::string& old_fname,
  35. std::unique_ptr<WritableFile>* result,
  36. const EnvOptions& options) override {
  37. PERF_TIMER_GUARD(env_reuse_writable_file_nanos);
  38. return EnvWrapper::ReuseWritableFile(fname, old_fname, result, options);
  39. }
  40. Status NewRandomRWFile(const std::string& fname,
  41. std::unique_ptr<RandomRWFile>* result,
  42. const EnvOptions& options) override {
  43. PERF_TIMER_GUARD(env_new_random_rw_file_nanos);
  44. return EnvWrapper::NewRandomRWFile(fname, result, options);
  45. }
  46. Status NewDirectory(const std::string& name,
  47. std::unique_ptr<Directory>* result) override {
  48. PERF_TIMER_GUARD(env_new_directory_nanos);
  49. return EnvWrapper::NewDirectory(name, result);
  50. }
  51. Status FileExists(const std::string& fname) override {
  52. PERF_TIMER_GUARD(env_file_exists_nanos);
  53. return EnvWrapper::FileExists(fname);
  54. }
  55. Status GetChildren(const std::string& dir,
  56. std::vector<std::string>* result) override {
  57. PERF_TIMER_GUARD(env_get_children_nanos);
  58. return EnvWrapper::GetChildren(dir, result);
  59. }
  60. Status GetChildrenFileAttributes(
  61. const std::string& dir, std::vector<FileAttributes>* result) override {
  62. PERF_TIMER_GUARD(env_get_children_file_attributes_nanos);
  63. return EnvWrapper::GetChildrenFileAttributes(dir, result);
  64. }
  65. Status DeleteFile(const std::string& fname) override {
  66. PERF_TIMER_GUARD(env_delete_file_nanos);
  67. return EnvWrapper::DeleteFile(fname);
  68. }
  69. Status CreateDir(const std::string& dirname) override {
  70. PERF_TIMER_GUARD(env_create_dir_nanos);
  71. return EnvWrapper::CreateDir(dirname);
  72. }
  73. Status CreateDirIfMissing(const std::string& dirname) override {
  74. PERF_TIMER_GUARD(env_create_dir_if_missing_nanos);
  75. return EnvWrapper::CreateDirIfMissing(dirname);
  76. }
  77. Status DeleteDir(const std::string& dirname) override {
  78. PERF_TIMER_GUARD(env_delete_dir_nanos);
  79. return EnvWrapper::DeleteDir(dirname);
  80. }
  81. Status GetFileSize(const std::string& fname, uint64_t* file_size) override {
  82. PERF_TIMER_GUARD(env_get_file_size_nanos);
  83. return EnvWrapper::GetFileSize(fname, file_size);
  84. }
  85. Status GetFileModificationTime(const std::string& fname,
  86. uint64_t* file_mtime) override {
  87. PERF_TIMER_GUARD(env_get_file_modification_time_nanos);
  88. return EnvWrapper::GetFileModificationTime(fname, file_mtime);
  89. }
  90. Status RenameFile(const std::string& src, const std::string& dst) override {
  91. PERF_TIMER_GUARD(env_rename_file_nanos);
  92. return EnvWrapper::RenameFile(src, dst);
  93. }
  94. Status LinkFile(const std::string& src, const std::string& dst) override {
  95. PERF_TIMER_GUARD(env_link_file_nanos);
  96. return EnvWrapper::LinkFile(src, dst);
  97. }
  98. Status LockFile(const std::string& fname, FileLock** lock) override {
  99. PERF_TIMER_GUARD(env_lock_file_nanos);
  100. return EnvWrapper::LockFile(fname, lock);
  101. }
  102. Status UnlockFile(FileLock* lock) override {
  103. PERF_TIMER_GUARD(env_unlock_file_nanos);
  104. return EnvWrapper::UnlockFile(lock);
  105. }
  106. Status NewLogger(const std::string& fname,
  107. std::shared_ptr<Logger>* result) override {
  108. PERF_TIMER_GUARD(env_new_logger_nanos);
  109. return EnvWrapper::NewLogger(fname, result);
  110. }
  111. };
  112. Env* NewTimedEnv(Env* base_env) { return new TimedEnv(base_env); }
  113. #else // ROCKSDB_LITE
  114. Env* NewTimedEnv(Env* /*base_env*/) { return nullptr; }
  115. #endif // !ROCKSDB_LITE
  116. } // namespace ROCKSDB_NAMESPACE