1*cc02d7e2SAndroid Build Coastguard Worker // 2*cc02d7e2SAndroid Build Coastguard Worker // 3*cc02d7e2SAndroid Build Coastguard Worker // Copyright 2015 gRPC authors. 4*cc02d7e2SAndroid Build Coastguard Worker // 5*cc02d7e2SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 6*cc02d7e2SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 7*cc02d7e2SAndroid Build Coastguard Worker // You may obtain a copy of the License at 8*cc02d7e2SAndroid Build Coastguard Worker // 9*cc02d7e2SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0 10*cc02d7e2SAndroid Build Coastguard Worker // 11*cc02d7e2SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 12*cc02d7e2SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 13*cc02d7e2SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*cc02d7e2SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 15*cc02d7e2SAndroid Build Coastguard Worker // limitations under the License. 16*cc02d7e2SAndroid Build Coastguard Worker // is % allowed in string 17*cc02d7e2SAndroid Build Coastguard Worker // 18*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPC_TEST_CPP_UTIL_METRICS_SERVER_H 19*cc02d7e2SAndroid Build Coastguard Worker #define GRPC_TEST_CPP_UTIL_METRICS_SERVER_H 20*cc02d7e2SAndroid Build Coastguard Worker 21*cc02d7e2SAndroid Build Coastguard Worker #include <map> 22*cc02d7e2SAndroid Build Coastguard Worker #include <mutex> 23*cc02d7e2SAndroid Build Coastguard Worker 24*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/server.h> 25*cc02d7e2SAndroid Build Coastguard Worker 26*cc02d7e2SAndroid Build Coastguard Worker #include "src/proto/grpc/testing/metrics.grpc.pb.h" 27*cc02d7e2SAndroid Build Coastguard Worker #include "src/proto/grpc/testing/metrics.pb.h" 28*cc02d7e2SAndroid Build Coastguard Worker 29*cc02d7e2SAndroid Build Coastguard Worker // 30*cc02d7e2SAndroid Build Coastguard Worker // This implements a Metrics server defined in 31*cc02d7e2SAndroid Build Coastguard Worker // src/proto/grpc/testing/metrics.proto. Any 32*cc02d7e2SAndroid Build Coastguard Worker // test service can use this to export Metrics (TODO (sreek): Only Gauges for 33*cc02d7e2SAndroid Build Coastguard Worker // now). 34*cc02d7e2SAndroid Build Coastguard Worker // 35*cc02d7e2SAndroid Build Coastguard Worker // Example: 36*cc02d7e2SAndroid Build Coastguard Worker // MetricsServiceImpl metricsImpl; 37*cc02d7e2SAndroid Build Coastguard Worker // .. 38*cc02d7e2SAndroid Build Coastguard Worker // // Create QpsGauge(s). Note: QpsGauges can be created even after calling 39*cc02d7e2SAndroid Build Coastguard Worker // // 'StartServer'. 40*cc02d7e2SAndroid Build Coastguard Worker // QpsGauge qps_gauge1 = metricsImpl.CreateQpsGauge("foo", is_present); 41*cc02d7e2SAndroid Build Coastguard Worker // // qps_gauge1 can now be used anywhere in the program by first making a 42*cc02d7e2SAndroid Build Coastguard Worker // // one-time call qps_gauge1.Reset() and then calling qps_gauge1.Incr() 43*cc02d7e2SAndroid Build Coastguard Worker // // every time to increment a query counter 44*cc02d7e2SAndroid Build Coastguard Worker // 45*cc02d7e2SAndroid Build Coastguard Worker // ... 46*cc02d7e2SAndroid Build Coastguard Worker // // Create the metrics server 47*cc02d7e2SAndroid Build Coastguard Worker // std::unique_ptr<grpc::Server> server = metricsImpl.StartServer(port); 48*cc02d7e2SAndroid Build Coastguard Worker // server->Wait(); // Note: This is blocking. 49*cc02d7e2SAndroid Build Coastguard Worker // 50*cc02d7e2SAndroid Build Coastguard Worker namespace grpc { 51*cc02d7e2SAndroid Build Coastguard Worker namespace testing { 52*cc02d7e2SAndroid Build Coastguard Worker 53*cc02d7e2SAndroid Build Coastguard Worker class QpsGauge { 54*cc02d7e2SAndroid Build Coastguard Worker public: 55*cc02d7e2SAndroid Build Coastguard Worker QpsGauge(); 56*cc02d7e2SAndroid Build Coastguard Worker 57*cc02d7e2SAndroid Build Coastguard Worker // Initialize the internal timer and reset the query count to 0 58*cc02d7e2SAndroid Build Coastguard Worker void Reset(); 59*cc02d7e2SAndroid Build Coastguard Worker 60*cc02d7e2SAndroid Build Coastguard Worker // Increment the query count by 1 61*cc02d7e2SAndroid Build Coastguard Worker void Incr(); 62*cc02d7e2SAndroid Build Coastguard Worker 63*cc02d7e2SAndroid Build Coastguard Worker // Return the current qps (i.e query count divided by the time since this 64*cc02d7e2SAndroid Build Coastguard Worker // QpsGauge object created (or Reset() was called)) 65*cc02d7e2SAndroid Build Coastguard Worker long Get(); 66*cc02d7e2SAndroid Build Coastguard Worker 67*cc02d7e2SAndroid Build Coastguard Worker private: 68*cc02d7e2SAndroid Build Coastguard Worker gpr_timespec start_time_; 69*cc02d7e2SAndroid Build Coastguard Worker long num_queries_; 70*cc02d7e2SAndroid Build Coastguard Worker std::mutex num_queries_mu_; 71*cc02d7e2SAndroid Build Coastguard Worker }; 72*cc02d7e2SAndroid Build Coastguard Worker 73*cc02d7e2SAndroid Build Coastguard Worker class MetricsServiceImpl final : public MetricsService::Service { 74*cc02d7e2SAndroid Build Coastguard Worker public: 75*cc02d7e2SAndroid Build Coastguard Worker grpc::Status GetAllGauges(ServerContext* context, const EmptyMessage* request, 76*cc02d7e2SAndroid Build Coastguard Worker ServerWriter<GaugeResponse>* writer) override; 77*cc02d7e2SAndroid Build Coastguard Worker 78*cc02d7e2SAndroid Build Coastguard Worker grpc::Status GetGauge(ServerContext* context, const GaugeRequest* request, 79*cc02d7e2SAndroid Build Coastguard Worker GaugeResponse* response) override; 80*cc02d7e2SAndroid Build Coastguard Worker 81*cc02d7e2SAndroid Build Coastguard Worker // Create a QpsGauge with name 'name'. is_present is set to true if the Gauge 82*cc02d7e2SAndroid Build Coastguard Worker // is already present in the map. 83*cc02d7e2SAndroid Build Coastguard Worker // NOTE: CreateQpsGauge can be called anytime (i.e before or after calling 84*cc02d7e2SAndroid Build Coastguard Worker // StartServer). 85*cc02d7e2SAndroid Build Coastguard Worker std::shared_ptr<QpsGauge> CreateQpsGauge(const std::string& name, 86*cc02d7e2SAndroid Build Coastguard Worker bool* already_present); 87*cc02d7e2SAndroid Build Coastguard Worker 88*cc02d7e2SAndroid Build Coastguard Worker std::unique_ptr<grpc::Server> StartServer(int port); 89*cc02d7e2SAndroid Build Coastguard Worker 90*cc02d7e2SAndroid Build Coastguard Worker private: 91*cc02d7e2SAndroid Build Coastguard Worker std::map<string, std::shared_ptr<QpsGauge>> qps_gauges_; 92*cc02d7e2SAndroid Build Coastguard Worker std::mutex mu_; 93*cc02d7e2SAndroid Build Coastguard Worker }; 94*cc02d7e2SAndroid Build Coastguard Worker 95*cc02d7e2SAndroid Build Coastguard Worker } // namespace testing 96*cc02d7e2SAndroid Build Coastguard Worker } // namespace grpc 97*cc02d7e2SAndroid Build Coastguard Worker 98*cc02d7e2SAndroid Build Coastguard Worker #endif // GRPC_TEST_CPP_UTIL_METRICS_SERVER_H 99