//////////////////////////////////////////////////////////////////////////////// /// DISCLAIMER /// /// Copyright 2016 ArangoDB GmbH, Cologne, Germany /// /// Licensed under the Apache License, Version 2.0 (the "License"); /// you may not use this file except in compliance with the License. /// You may obtain a copy of the License at /// /// http://www.apache.org/licenses/LICENSE-2.0 /// /// Unless required by applicable law or agreed to in writing, software /// distributed under the License is distributed on an "AS IS" BASIS, /// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. /// See the License for the specific language governing permissions and /// limitations under the License. /// /// Copyright holder is ArangoDB GmbH, Cologne, Germany /// /// @author Dr. Frank Celler //////////////////////////////////////////////////////////////////////////////// #ifndef APPLICATION_FEATURES_STATISTICS_FEATURE_H #define APPLICATION_FEATURES_STATISTICS_FEATURE_H 1 #include #include "ApplicationFeatures/ApplicationFeature.h" #include "Basics/Mutex.h" #include "Basics/Thread.h" #include "Rest/CommonDefines.h" #include "Statistics/figures.h" namespace arangodb { namespace basics { extern Mutex TRI_RequestsStatisticsMutex; extern std::vector const TRI_BytesReceivedDistributionVectorStatistics; extern std::vector const TRI_BytesSentDistributionVectorStatistics; extern std::vector const TRI_ConnectionTimeDistributionVectorStatistics; extern std::vector const TRI_RequestTimeDistributionVectorStatistics; extern StatisticsCounter TRI_AsyncRequestsStatistics; extern StatisticsCounter TRI_HttpConnectionsStatistics; extern StatisticsCounter TRI_TotalRequestsStatistics; constexpr size_t MethodRequestsStatisticsSize = ((size_t)arangodb::rest::RequestType::ILLEGAL) + 1; extern std::array TRI_MethodRequestsStatistics; extern StatisticsDistribution TRI_BytesReceivedDistributionStatistics; extern StatisticsDistribution TRI_BytesSentDistributionStatistics; extern StatisticsDistribution TRI_ConnectionTimeDistributionStatistics; extern StatisticsDistribution TRI_IoTimeDistributionStatistics; extern StatisticsDistribution TRI_QueueTimeDistributionStatistics; extern StatisticsDistribution TRI_RequestTimeDistributionStatistics; extern StatisticsDistribution TRI_TotalTimeDistributionStatistics; extern StatisticsDistribution TRI_BytesReceivedDistributionStatisticsUser; extern StatisticsDistribution TRI_BytesSentDistributionStatisticsUser; extern StatisticsDistribution TRI_IoTimeDistributionStatisticsUser; extern StatisticsDistribution TRI_QueueTimeDistributionStatisticsUser; extern StatisticsDistribution TRI_RequestTimeDistributionStatisticsUser; extern StatisticsDistribution TRI_TotalTimeDistributionStatisticsUser; } // namespace basics namespace stats { class Descriptions; } class StatisticsThread; class StatisticsWorker; class StatisticsFeature final : public application_features::ApplicationFeature { public: static bool enabled() { return STATISTICS != nullptr && STATISTICS->_statistics; } static double time() { return TRI_microtime(); } private: static StatisticsFeature* STATISTICS; public: explicit StatisticsFeature(application_features::ApplicationServer& server); void collectOptions(std::shared_ptr) override final; void validateOptions(std::shared_ptr) override final; void prepare() override final; void start() override final; void stop() override final; static stats::Descriptions const* descriptions() { if (STATISTICS != nullptr) { return STATISTICS->_descriptions.get(); } return nullptr; } private: bool _statistics; bool _statisticsHistory; bool _statisticsHistoryTouched; std::unique_ptr _descriptions; std::unique_ptr _statisticsThread; std::unique_ptr _statisticsWorker; }; } // namespace arangodb #endif