mirror of https://github.com/grpc/grpc.git
Conflicts: Makefile build.json test/cpp/qps/worker.ccpull/1241/head
commit
217b7f0e80
47 changed files with 802 additions and 253 deletions
@ -0,0 +1,40 @@ |
|||||||
|
#!/bin/sh |
||||||
|
# Copyright 2015, Google Inc. |
||||||
|
# All rights reserved. |
||||||
|
# |
||||||
|
# Redistribution and use in source and binary forms, with or without |
||||||
|
# modification, are permitted provided that the following conditions are |
||||||
|
# met: |
||||||
|
# |
||||||
|
# * Redistributions of source code must retain the above copyright |
||||||
|
# notice, this list of conditions and the following disclaimer. |
||||||
|
# * Redistributions in binary form must reproduce the above |
||||||
|
# copyright notice, this list of conditions and the following disclaimer |
||||||
|
# in the documentation and/or other materials provided with the |
||||||
|
# distribution. |
||||||
|
# * Neither the name of Google Inc. nor the names of its |
||||||
|
# contributors may be used to endorse or promote products derived from |
||||||
|
# this software without specific prior written permission. |
||||||
|
# |
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||||
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||||
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||||
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||||
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||||
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||||
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||||
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||||
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||||
|
|
||||||
|
|
||||||
|
set +e |
||||||
|
cd $(dirname $0) |
||||||
|
|
||||||
|
gen_code='../tests/generated_code' |
||||||
|
interop='../tests/interop' |
||||||
|
|
||||||
|
protoc-gen-php -i $gen_code -o $gen_code $gen_code/math.proto |
||||||
|
|
||||||
|
protoc-gen-php -i $interop -o $interop $interop/test.proto |
@ -0,0 +1,94 @@ |
|||||||
|
/*
|
||||||
|
* |
||||||
|
* Copyright 2015, Google Inc. |
||||||
|
* All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are |
||||||
|
* met: |
||||||
|
* |
||||||
|
* * Redistributions of source code must retain the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer. |
||||||
|
* * Redistributions in binary form must reproduce the above |
||||||
|
* copyright notice, this list of conditions and the following disclaimer |
||||||
|
* in the documentation and/or other materials provided with the |
||||||
|
* distribution. |
||||||
|
* * Neither the name of Google Inc. nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* |
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#include "test/cpp/qps/report.h" |
||||||
|
|
||||||
|
#include <grpc/support/log.h> |
||||||
|
#include "test/cpp/qps/stats.h" |
||||||
|
|
||||||
|
namespace grpc { |
||||||
|
namespace testing { |
||||||
|
|
||||||
|
// QPS: XXX
|
||||||
|
void ReportQPS(const ScenarioResult& result) { |
||||||
|
gpr_log(GPR_INFO, "QPS: %.1f", |
||||||
|
result.latencies.Count() / |
||||||
|
average(result.client_resources, |
||||||
|
[](ResourceUsage u) { return u.wall_time; })); |
||||||
|
} |
||||||
|
|
||||||
|
// QPS: XXX (YYY/server core)
|
||||||
|
void ReportQPSPerCore(const ScenarioResult& result, const ServerConfig& server_config) { |
||||||
|
auto qps =
|
||||||
|
result.latencies.Count() / |
||||||
|
average(result.client_resources, |
||||||
|
[](ResourceUsage u) { return u.wall_time; }); |
||||||
|
|
||||||
|
gpr_log(GPR_INFO, "QPS: %.1f (%.1f/server core)", qps, qps/server_config.threads()); |
||||||
|
} |
||||||
|
|
||||||
|
// Latency (50/90/95/99/99.9%-ile): AA/BB/CC/DD/EE us
|
||||||
|
void ReportLatency(const ScenarioResult& result) { |
||||||
|
gpr_log(GPR_INFO, "Latencies (50/90/95/99/99.9%%-ile): %.1f/%.1f/%.1f/%.1f/%.1f us", |
||||||
|
result.latencies.Percentile(50) / 1000, |
||||||
|
result.latencies.Percentile(90) / 1000, |
||||||
|
result.latencies.Percentile(95) / 1000, |
||||||
|
result.latencies.Percentile(99) / 1000, |
||||||
|
result.latencies.Percentile(99.9) / 1000); |
||||||
|
} |
||||||
|
|
||||||
|
void ReportTimes(const ScenarioResult& result) { |
||||||
|
gpr_log(GPR_INFO, "Server system time: %.2f%%", |
||||||
|
100.0 * sum(result.server_resources, |
||||||
|
[](ResourceUsage u) { return u.system_time; }) / |
||||||
|
sum(result.server_resources, |
||||||
|
[](ResourceUsage u) { return u.wall_time; })); |
||||||
|
gpr_log(GPR_INFO, "Server user time: %.2f%%", |
||||||
|
100.0 * sum(result.server_resources, |
||||||
|
[](ResourceUsage u) { return u.user_time; }) / |
||||||
|
sum(result.server_resources, |
||||||
|
[](ResourceUsage u) { return u.wall_time; })); |
||||||
|
gpr_log(GPR_INFO, "Client system time: %.2f%%", |
||||||
|
100.0 * sum(result.client_resources, |
||||||
|
[](ResourceUsage u) { return u.system_time; }) / |
||||||
|
sum(result.client_resources, |
||||||
|
[](ResourceUsage u) { return u.wall_time; })); |
||||||
|
gpr_log(GPR_INFO, "Client user time: %.2f%%", |
||||||
|
100.0 * sum(result.client_resources, |
||||||
|
[](ResourceUsage u) { return u.user_time; }) / |
||||||
|
sum(result.client_resources, |
||||||
|
[](ResourceUsage u) { return u.wall_time; })); |
||||||
|
} |
||||||
|
|
||||||
|
} // namespace testing
|
||||||
|
} // namespace grpc
|
@ -0,0 +1,57 @@ |
|||||||
|
/*
|
||||||
|
* |
||||||
|
* Copyright 2015, Google Inc. |
||||||
|
* All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are |
||||||
|
* met: |
||||||
|
* |
||||||
|
* * Redistributions of source code must retain the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer. |
||||||
|
* * Redistributions in binary form must reproduce the above |
||||||
|
* copyright notice, this list of conditions and the following disclaimer |
||||||
|
* in the documentation and/or other materials provided with the |
||||||
|
* distribution. |
||||||
|
* * Neither the name of Google Inc. nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* |
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
||||||
|
* |
||||||
|
*/ |
||||||
|
|
||||||
|
#ifndef TEST_QPS_REPORT_H |
||||||
|
#define TEST_QPS_REPORT_H |
||||||
|
|
||||||
|
#include "test/cpp/qps/driver.h" |
||||||
|
|
||||||
|
namespace grpc { |
||||||
|
namespace testing { |
||||||
|
|
||||||
|
// QPS: XXX
|
||||||
|
void ReportQPS(const ScenarioResult& result); |
||||||
|
// QPS: XXX (YYY/server core)
|
||||||
|
void ReportQPSPerCore(const ScenarioResult& result, const ServerConfig& config); |
||||||
|
// Latency (50/90/95/99/99.9%-ile): AA/BB/CC/DD/EE us
|
||||||
|
void ReportLatency(const ScenarioResult& result); |
||||||
|
// Server system time: XX%
|
||||||
|
// Server user time: XX%
|
||||||
|
// Client system time: XX%
|
||||||
|
// Client user time: XX%
|
||||||
|
void ReportTimes(const ScenarioResult& result); |
||||||
|
|
||||||
|
} // namespace testing
|
||||||
|
} // namespace grpc
|
||||||
|
|
||||||
|
#endif |
Loading…
Reference in new issue