//////////////////////////////////////////////////////////////////////////////// /// @brief statistics handler /// /// @file /// /// DISCLAIMER /// /// Copyright 2004-2012 triagens 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 triAGENS GmbH, Cologne, Germany /// /// @author Dr. Frank Celler /// @author Copyright 2010-2012, triAGENS GmbH, Cologne, Germany //////////////////////////////////////////////////////////////////////////////// #ifndef TRIAGENS_REST_HANDLER_REQUEST_STATISTICS_HANDLER_H #define TRIAGENS_REST_HANDLER_REQUEST_STATISTICS_HANDLER_H 1 #include "RestHandler/StatisticsBaseHandler.h" // ----------------------------------------------------------------------------- // --SECTION-- class RestDocumentHandler // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup ArangoDB /// @{ //////////////////////////////////////////////////////////////////////////////// namespace triagens { namespace arango { //////////////////////////////////////////////////////////////////////////////// /// @brief statistics handler //////////////////////////////////////////////////////////////////////////////// class RequestStatisticsHandler : public StatisticsBaseHandler { //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- constructors and destructors // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup ArangoDB /// @{ //////////////////////////////////////////////////////////////////////////////// public: //////////////////////////////////////////////////////////////////////////////// /// @brief constructs a new handler //////////////////////////////////////////////////////////////////////////////// RequestStatisticsHandler (triagens::rest::HttpRequest*); //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// // ----------------------------------------------------------------------------- // --SECTION-- StatisticsBaseHandler methods // ----------------------------------------------------------------------------- //////////////////////////////////////////////////////////////////////////////// /// @addtogroup ArangoDB /// @{ //////////////////////////////////////////////////////////////////////////////// public: //////////////////////////////////////////////////////////////////////////////// /// {@inheritDoc} /// /// @RESTHEADER{GET /_admin/request-statistics,reads the request statistics} /// /// @REST{GET /_admin/request-statistics?granalurity=@FA{granularity}&figures=@FA{figures}&length=@FA{length}} /// /// The call returns statistics about the current and past requests. The /// following parameter control which information is returned. /// /// - @FA{granularity}: use @LIT{minutes} for a granularity of minutes, /// @LIT{hours} for hours, and @LIT{days} for days. The default is /// @LIT{minutes}. /// /// - @FA{figures}: a list of figures, comma-separated. Possible figures are /// @LIT{totalTime}, @LIT{queueTime}, @LIT{requestTime}, @LIT{bytesSent}, and /// @LIT{bytesReceived}. You can use @LIT{all} to get all figures. The default /// is @LIT{totalTime}, @LIT{bytesSent}, and @LIT{bytesReceived}. /// /// - @FA{length}: If you want a time series, the maximal length of the series /// as integer. You can use @LIT{all} to get all available information. You can /// use @LIT{current} to get the latest interval. /// /// The returned statistics objects contains information of the request figures. /// /// - @LIT{resolution}: the resolution in seconds aka granularity. The length of /// the time intervals. /// /// - @LIT{start}: a list of time stamps in seconds since 1970-01-01. Each entry /// marks the start of an interval for which the figures were computed. The length /// of the interval is given by @LIT{resolution}. /// /// - @LIT{length}: the number of returned intervals. /// /// - @LIT{totalLength}: the number of available intervals. /// /// - @LIT{totalTime}: the distribution of the total time. /// /// - @LIT{queueTime}: the distribution of the queue time. /// /// - @LIT{requestTime}: the distribution of the request time. /// /// - @LIT{bytesSent}: the distribution of the number of bytes sent. /// /// - @LIT{bytesReceived}: the distribution of the number of bytes received. /// /// A distribution contains the following fields: /// /// - @LIT{count}: a list describing the number of requests per time /// interval. This corresponds to the field @LIT{start}. /// /// - @LIT{mean}: a list describing the mean of the values per time /// interval. This corresponds to the field @LIT{start}. /// /// - @LIT{max}: a list describing the maximum of the values per time /// interval. This corresponds to the field @LIT{start}. /// /// - @LIT{cuts}: a list [N1, N2, ... Nx] of numbers defining the intervals for /// the figure. The first interval is [0 .. N1), the last interval is [Nx /// .. INF). /// /// - @LIT{distribution}: a list describing the distribution of the values per /// time interval. This corresponds to the field @LIT{start}. Each entry of the /// list is again a list. This list describes the number of requests per cut and /// corresponds to the field @{cuts}. /// /// If @FA{length} is @LIT{current} the figures for the current interval are returned. /// /// @EXAMPLES /// /// A time-series: /// /// @EXAMPLE{request-statistics,request statistics as time series} /// /// The current figures: /// /// @EXAMPLE{request-statistics-current,current request statistics} //////////////////////////////////////////////////////////////////////////////// void compute (TRI_statistics_granularity_e, size_t length); }; } } //////////////////////////////////////////////////////////////////////////////// /// @} //////////////////////////////////////////////////////////////////////////////// #endif // ----------------------------------------------------------------------------- // --SECTION-- END-OF-FILE // ----------------------------------------------------------------------------- // Local Variables: // mode: outline-minor // outline-regexp: "^\\(/// @brief\\|/// {@inheritDoc}\\|/// @addtogroup\\|/// @page\\|// --SECTION--\\|/// @\\}\\)" // End: