blob: aa9bfed23d84849de38f2461f762f2effb1616e8 [file] [log] [blame]
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -07001/*
2 *
3 * Copyright 2015, Google Inc.
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 * * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * * Redistributions in binary form must reproduce the above
13 * copyright notice, this list of conditions and the following disclaimer
14 * in the documentation and/or other materials provided with the
15 * distribution.
16 * * Neither the name of Google Inc. nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 *is % allowed in string
32 */
33#ifndef GRPC_TEST_CPP_METRICS_SERVER_H
34#define GRPC_TEST_CPP_METRICS_SERVER_H
35
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070036#include <map>
37#include <mutex>
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070038
Craig Tiller1b4e3302015-12-17 16:35:00 -080039#include "src/proto/grpc/testing/metrics.grpc.pb.h"
40#include "src/proto/grpc/testing/metrics.pb.h"
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070041
42/*
Craig Tiller1b4e3302015-12-17 16:35:00 -080043 * This implements a Metrics server defined in
44 * src/proto/grpc/testing/metrics.proto. Any
Sree Kuchibhotla4d0f2f92015-11-03 15:55:43 -080045 * test service can use this to export Metrics (TODO (sreek): Only Gauges for
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070046 * now).
47 *
48 * Example:
49 * MetricsServiceImpl metricsImpl;
50 * ..
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070051 * // Create QpsGauge(s). Note: QpsGauges can be created even after calling
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070052 * // 'StartServer'.
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070053 * QpsGauge qps_gauge1 = metricsImpl.CreateQpsGauge("foo", is_present);
54 * // qps_gauge1 can now be used anywhere in the program by first making a
55 * // one-time call qps_gauge1.Reset() and then calling qps_gauge1.Incr()
56 * // every time to increment a query counter
57 *
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070058 * ...
59 * // Create the metrics server
60 * std::unique_ptr<grpc::Server> server = metricsImpl.StartServer(port);
61 * server->Wait(); // Note: This is blocking.
62 */
63namespace grpc {
64namespace testing {
65
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070066class QpsGauge {
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070067 public:
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070068 QpsGauge();
69
70 // Initialize the internal timer and reset the query count to 0
71 void Reset();
72
73 // Increment the query count by 1
74 void Incr();
75
76 // Return the current qps (i.e query count divided by the time since this
77 // QpsGauge object created (or Reset() was called))
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070078 long Get();
79
80 private:
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070081 gpr_timespec start_time_;
82 long num_queries_;
83 std::mutex num_queries_mu_;
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070084};
85
86class MetricsServiceImpl GRPC_FINAL : public MetricsService::Service {
87 public:
Sree Kuchibhotla4d0f2f92015-11-03 15:55:43 -080088 grpc::Status GetAllGauges(ServerContext* context, const EmptyMessage* request,
89 ServerWriter<GaugeResponse>* writer) GRPC_OVERRIDE;
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070090
Sree Kuchibhotla4d0f2f92015-11-03 15:55:43 -080091 grpc::Status GetGauge(ServerContext* context, const GaugeRequest* request,
92 GaugeResponse* response) GRPC_OVERRIDE;
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070093
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070094 // Create a QpsGauge with name 'name'. is_present is set to true if the Gauge
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070095 // is already present in the map.
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070096 // NOTE: CreateQpsGauge can be called anytime (i.e before or after calling
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -070097 // StartServer).
Sree Kuchibhotla3714e302016-04-22 09:50:46 -070098 std::shared_ptr<QpsGauge> CreateQpsGauge(const grpc::string& name,
Sree Kuchibhotla8c065a72016-04-26 12:11:42 -070099 bool* already_present);
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -0700100
101 std::unique_ptr<grpc::Server> StartServer(int port);
102
103 private:
Sree Kuchibhotla3714e302016-04-22 09:50:46 -0700104 std::map<string, std::shared_ptr<QpsGauge>> qps_gauges_;
Sree Kuchibhotlab5e98c52015-10-27 22:55:26 -0700105 std::mutex mu_;
106};
107
108} // namespace testing
109} // namespace grpc
110
111#endif // GRPC_TEST_CPP_METRICS_SERVER_H