diff --git a/src/h2load.cc b/src/h2load.cc index 0e2f10e9..2e7d2b74 100644 --- a/src/h2load.cc +++ b/src/h2load.cc @@ -731,7 +731,8 @@ void Client::signal_write() { ev_io_start(worker->loop, &wev); } Worker::Worker(uint32_t id, SSL_CTX *ssl_ctx, size_t req_todo, size_t nclients, ssize_t rate, Config *config) : stats(req_todo), loop(ev_loop_new(0)), ssl_ctx(ssl_ctx), config(config), - id(id), tls_info_report_done(false), current_second(0), nconns_made(0), nclients(nclients), rate(rate) { + id(id), tls_info_report_done(false), current_second(0), nconns_made(0), + nclients(nclients), rate(rate) { stats.req_todo = req_todo; progress_interval = std::max((size_t)1, req_todo / 10); auto nreqs_per_client = req_todo / nclients; @@ -1028,13 +1029,16 @@ void print_help(std::ostream &out) { Options: -n, --requests= Number of requests. - Default: )" << config.nreqs << R"( + Default: )" + << config.nreqs << R"( -c, --clients= Number of concurrent clients. - Default: )" << config.nclients << R"( + Default: )" + << config.nclients << R"( -t, --threads= Number of native threads. - Default: )" << config.nthreads << R"( + Default: )" + << config.nthreads << R"( -i, --input-file= Path of a file with multiple URIs are separated by EOLs. This option will disable URIs getting from command-line. @@ -1051,13 +1055,15 @@ Options: -w, --window-bits= Sets the stream level initial window size to (2**)-1. For SPDY, 2** is used instead. - Default: )" << config.window_bits << R"( + Default: )" + << config.window_bits << R"( -W, --connection-window-bits= Sets the connection level initial window size to (2**)-1. For SPDY, if is strictly less than 16, this option is ignored. Otherwise 2** is used for SPDY. - Default: )" << config.connection_window_bits << R"( + Default: )" + << config.connection_window_bits << R"( -H, --header=
Add/Override a header to the requests. --ciphers= @@ -1075,7 +1081,8 @@ Options: Available protocol: )"; #endif // !HAVE_SPDYLAY out << NGHTTP2_CLEARTEXT_PROTO_VERSION_ID << R"( - Default: )" << NGHTTP2_CLEARTEXT_PROTO_VERSION_ID << R"( + Default: )" + << NGHTTP2_CLEARTEXT_PROTO_VERSION_ID << R"( -d, --data= Post FILE to server. The request method is changed to POST. @@ -1100,7 +1107,8 @@ Options: -v, --verbose Output debug information. --version Display version information and exit. - -h, --help Display this help and exit.)" << std::endl; + -h, --help Display this help and exit.)" + << std::endl; } } // namespace @@ -1333,7 +1341,8 @@ int main(int argc, char **argv) { } if (config.is_rate_mode() && config.nconns < (ssize_t)config.nthreads) { - std::cerr << "-C, -t: the total number of connections must be greater than or equal " + std::cerr << "-C, -t: the total number of connections must be greater than " + "or equal " << "to the number of threads." << std::endl; exit(EXIT_FAILURE); } @@ -1459,11 +1468,12 @@ int main(int argc, char **argv) { config.nreqs, (size_t)(config.max_concurrent_streams * config.nconns)) << " total requests." << std::endl; - actual_nreqs = std::min(config.nreqs, (size_t)(config.max_concurrent_streams * config.nreqs)); + actual_nreqs = std::min( + config.nreqs, (size_t)(config.max_concurrent_streams * config.nreqs)); } } else { - if (config.is_rate_mode() && config.max_concurrent_streams != 0 && - (n_time != c_time) && config.nreqs == 1 && config.nconns != 0) { + if (config.is_rate_mode() && config.max_concurrent_streams != 0 && + (n_time != c_time) && config.nreqs == 1 && config.nconns != 0) { actual_nreqs = config.max_concurrent_streams * config.nconns; } } @@ -1540,7 +1550,7 @@ int main(int argc, char **argv) { if (config.is_rate_mode()) { - // set various config values + // set various config values if ((int)config.nreqs < config.nconns) { seconds = c_time; } else if (config.nconns == 0) { @@ -1564,11 +1574,12 @@ int main(int argc, char **argv) { auto nclients_extra_per_thread = 0; auto nclients_extra_rem_per_thread = 0; // In rate mode, we want each Worker to create a total of - // C/t connections. + // C/t connections. if (config.is_rate_mode()) { nclients_extra = config.nconns - (seconds * config.rate); nclients_extra_per_thread = nclients_extra / (ssize_t)config.nthreads; - nclients_extra_rem_per_thread = (ssize_t)nclients_extra % (ssize_t)config.nthreads; + nclients_extra_rem_per_thread = + (ssize_t)nclients_extra % (ssize_t)config.nthreads; } std::cout << "starting benchmark..." << std::endl; @@ -1585,7 +1596,8 @@ int main(int argc, char **argv) { auto rate = rate_per_thread + (rate_per_thread_rem-- > 0); auto nclients = nclients_per_thread + (nclients_rem-- > 0); if (config.is_rate_mode()) { - nclients = rate * seconds + nclients_extra_per_thread + (nclients_extra_rem_per_thread-- > 0); + nclients = rate * seconds + nclients_extra_per_thread + + (nclients_extra_rem_per_thread-- > 0); nreqs = nclients * config.max_concurrent_streams; } std::cout << "spawning thread #" << i << ": " << nclients @@ -1603,14 +1615,16 @@ int main(int argc, char **argv) { auto nclients_last = nclients_per_thread + (nclients_rem-- > 0); auto rate_last = rate_per_thread + (rate_per_thread_rem-- > 0); if (config.is_rate_mode()) { - nclients_last = rate_last * seconds + nclients_extra_per_thread + (nclients_extra_rem_per_thread-- > 0); + nclients_last = rate_last * seconds + nclients_extra_per_thread + + (nclients_extra_rem_per_thread-- > 0); nreqs_last = nclients_last * config.max_concurrent_streams; } std::cout << "spawning thread #" << (config.nthreads - 1) << ": " << nclients_last << " concurrent clients, " << nreqs_last << " total requests" << std::endl; - workers.push_back(make_unique( - config.nthreads - 1, ssl_ctx, nreqs_last, nclients_last, rate_last, &config)); + workers.push_back(make_unique(config.nthreads - 1, ssl_ctx, + nreqs_last, nclients_last, rate_last, + &config)); workers.back()->run(); #ifndef NOTHREADS diff --git a/src/h2load.h b/src/h2load.h index f813546d..20d323fe 100644 --- a/src/h2load.h +++ b/src/h2load.h @@ -183,8 +183,8 @@ struct Worker { ev_timer timeout_watcher; ssize_t rate; - Worker(uint32_t id, SSL_CTX *ssl_ctx, size_t nreq_todo, size_t nclients, ssize_t rate, - Config *config); + Worker(uint32_t id, SSL_CTX *ssl_ctx, size_t nreq_todo, size_t nclients, + ssize_t rate, Config *config); ~Worker(); Worker(Worker &&o) = default; void run();