| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- // Copyright (c) 2011-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).
- #pragma once
- #include <string>
- #include "monitoring/thread_status_updater.h"
- #include "rocksdb/db.h"
- #include "rocksdb/env.h"
- #include "rocksdb/thread_status.h"
- namespace ROCKSDB_NAMESPACE {
- class ColumnFamilyData;
- // The static utility class for updating thread-local status.
- //
- // The thread-local status is updated via the thread-local cached
- // pointer thread_updater_local_cache_. During each function call,
- // when ThreadStatusUtil finds thread_updater_local_cache_ is
- // left uninitialized (determined by thread_updater_initialized_),
- // it will tries to initialize it using the return value of
- // Env::GetThreadStatusUpdater(). When thread_updater_local_cache_
- // is initialized by a non-null pointer, each function call will
- // then update the status of the current thread. Otherwise,
- // all function calls to ThreadStatusUtil will be no-op.
- class ThreadStatusUtil {
- public:
- // Register the current thread for tracking.
- static void RegisterThread(
- const Env* env, ThreadStatus::ThreadType thread_type);
- // Unregister the current thread.
- static void UnregisterThread();
- // Create an entry in the global ColumnFamilyInfo table for the
- // specified column family. This function should be called only
- // when the current thread does not hold db_mutex.
- static void NewColumnFamilyInfo(const DB* db, const ColumnFamilyData* cfd,
- const std::string& cf_name, const Env* env);
- // Erase the ConstantColumnFamilyInfo that is associated with the
- // specified ColumnFamilyData. This function should be called only
- // when the current thread does not hold db_mutex.
- static void EraseColumnFamilyInfo(const ColumnFamilyData* cfd);
- // Erase all ConstantColumnFamilyInfo that is associated with the
- // specified db instance. This function should be called only when
- // the current thread does not hold db_mutex.
- static void EraseDatabaseInfo(const DB* db);
- // Update the thread status to indicate the current thread is doing
- // something related to the specified column family.
- static void SetColumnFamily(const ColumnFamilyData* cfd, const Env* env,
- bool enable_thread_tracking);
- static void SetThreadOperation(ThreadStatus::OperationType type);
- static ThreadStatus::OperationStage SetThreadOperationStage(
- ThreadStatus::OperationStage stage);
- static void SetThreadOperationProperty(
- int code, uint64_t value);
- static void IncreaseThreadOperationProperty(
- int code, uint64_t delta);
- static void SetThreadState(ThreadStatus::StateType type);
- static void ResetThreadStatus();
- #ifndef NDEBUG
- static void TEST_SetStateDelay(
- const ThreadStatus::StateType state, int micro);
- static void TEST_StateDelay(const ThreadStatus::StateType state);
- #endif
- protected:
- // Initialize the thread-local ThreadStatusUpdater when it finds
- // the cached value is nullptr. Returns true if it has cached
- // a non-null pointer.
- static bool MaybeInitThreadLocalUpdater(const Env* env);
- #ifdef ROCKSDB_USING_THREAD_STATUS
- // A boolean flag indicating whether thread_updater_local_cache_
- // is initialized. It is set to true when an Env uses any
- // ThreadStatusUtil functions using the current thread other
- // than UnregisterThread(). It will be set to false when
- // UnregisterThread() is called.
- //
- // When this variable is set to true, thread_updater_local_cache_
- // will not be updated until this variable is again set to false
- // in UnregisterThread().
- static __thread bool thread_updater_initialized_;
- // The thread-local cached ThreadStatusUpdater that caches the
- // thread_status_updater_ of the first Env that uses any ThreadStatusUtil
- // function other than UnregisterThread(). This variable will
- // be cleared when UnregisterThread() is called.
- //
- // When this variable is set to a non-null pointer, then the status
- // of the current thread will be updated when a function of
- // ThreadStatusUtil is called. Otherwise, all functions of
- // ThreadStatusUtil will be no-op.
- //
- // When thread_updater_initialized_ is set to true, this variable
- // will not be updated until this thread_updater_initialized_ is
- // again set to false in UnregisterThread().
- static __thread ThreadStatusUpdater* thread_updater_local_cache_;
- #else
- static bool thread_updater_initialized_;
- static ThreadStatusUpdater* thread_updater_local_cache_;
- #endif
- };
- // A helper class for updating thread state. It will set the
- // thread state according to the input parameter in its constructor
- // and set the thread state to the previous state in its destructor.
- class AutoThreadOperationStageUpdater {
- public:
- explicit AutoThreadOperationStageUpdater(
- ThreadStatus::OperationStage stage);
- ~AutoThreadOperationStageUpdater();
- #ifdef ROCKSDB_USING_THREAD_STATUS
- private:
- ThreadStatus::OperationStage prev_stage_;
- #endif
- };
- } // namespace ROCKSDB_NAMESPACE
|