2014-07-08 17:38:43 +02:00
|
|
|
|
2015-05-12 17:44:37 +02:00
|
|
|
.. GENERATED by help2rst.py. DO NOT EDIT DIRECTLY.
|
|
|
|
|
2015-04-17 16:14:23 +02:00
|
|
|
.. program:: h2load
|
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
h2load(1)
|
|
|
|
=========
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2015-01-09 16:37:42 +01:00
|
|
|
|
2014-10-27 16:35:44 +01:00
|
|
|
**h2load** [OPTIONS]... [URI]...
|
2014-07-08 17:38:43 +02:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
2015-01-09 16:37:42 +01:00
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
benchmarking tool for HTTP/2 and SPDY server
|
|
|
|
|
2015-01-09 16:37:42 +01:00
|
|
|
.. describe:: <URI>
|
2014-07-08 17:38:43 +02:00
|
|
|
|
2015-01-15 16:10:16 +01:00
|
|
|
Specify URI to access. Multiple URIs can be specified.
|
|
|
|
URIs are used in this order for each client. All URIs
|
|
|
|
are used, then first URI is used and then 2nd URI, and
|
|
|
|
so on. The scheme, host and port in the subsequent
|
|
|
|
URIs, if present, are ignored. Those in the first URI
|
2015-08-29 17:24:11 +02:00
|
|
|
are used solely. Definition of a base URI overrides all
|
|
|
|
scheme, host or port values.
|
2014-07-08 17:38:43 +02:00
|
|
|
|
2015-02-01 10:33:24 +01:00
|
|
|
OPTIONS
|
|
|
|
-------
|
2014-07-08 17:38:43 +02:00
|
|
|
|
|
|
|
.. option:: -n, --requests=<N>
|
|
|
|
|
2015-01-09 16:37:42 +01:00
|
|
|
Number of requests.
|
|
|
|
|
|
|
|
Default: ``1``
|
2014-07-08 17:38:43 +02:00
|
|
|
|
|
|
|
.. option:: -c, --clients=<N>
|
|
|
|
|
2015-01-09 16:37:42 +01:00
|
|
|
Number of concurrent clients.
|
|
|
|
|
|
|
|
Default: ``1``
|
2014-07-08 17:38:43 +02:00
|
|
|
|
|
|
|
.. option:: -t, --threads=<N>
|
|
|
|
|
2015-01-09 16:37:42 +01:00
|
|
|
Number of native threads.
|
|
|
|
|
|
|
|
Default: ``1``
|
2014-07-08 17:38:43 +02:00
|
|
|
|
2015-07-28 17:01:12 +02:00
|
|
|
.. option:: -i, --input-file=<PATH>
|
2014-10-27 16:35:44 +01:00
|
|
|
|
2015-05-12 03:49:42 +02:00
|
|
|
Path of a file with multiple URIs are separated by EOLs.
|
2015-01-15 16:10:16 +01:00
|
|
|
This option will disable URIs getting from command-line.
|
2015-07-28 17:01:12 +02:00
|
|
|
If '-' is given as <PATH>, URIs will be read from stdin.
|
2015-01-15 16:10:16 +01:00
|
|
|
URIs are used in this order for each client. All URIs
|
|
|
|
are used, then first URI is used and then 2nd URI, and
|
|
|
|
so on. The scheme, host and port in the subsequent
|
|
|
|
URIs, if present, are ignored. Those in the first URI
|
2015-08-29 17:24:11 +02:00
|
|
|
are used solely. Definition of a base URI overrides all
|
|
|
|
scheme, host or port values.
|
2014-10-27 16:35:44 +01:00
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
.. option:: -m, --max-concurrent-streams=(auto|<N>)
|
|
|
|
|
2015-01-15 16:10:16 +01:00
|
|
|
Max concurrent streams to issue per session. If "auto"
|
|
|
|
is given, the number of given URIs is used.
|
2015-01-09 16:37:42 +01:00
|
|
|
|
|
|
|
Default: ``auto``
|
2014-07-08 17:38:43 +02:00
|
|
|
|
|
|
|
.. option:: -w, --window-bits=<N>
|
|
|
|
|
2015-01-15 16:10:16 +01:00
|
|
|
Sets the stream level initial window size to (2\*\*<N>)-1.
|
|
|
|
For SPDY, 2**<N> is used instead.
|
2014-07-08 17:38:43 +02:00
|
|
|
|
2015-04-27 15:36:34 +02:00
|
|
|
Default: ``30``
|
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
.. option:: -W, --connection-window-bits=<N>
|
|
|
|
|
2015-01-15 16:10:16 +01:00
|
|
|
Sets the connection level initial window size to
|
|
|
|
(2**<N>)-1. For SPDY, if <N> is strictly less than 16,
|
|
|
|
this option is ignored. Otherwise 2\*\*<N> is used for
|
|
|
|
SPDY.
|
2014-07-08 17:38:43 +02:00
|
|
|
|
2015-04-27 15:36:34 +02:00
|
|
|
Default: ``30``
|
|
|
|
|
2014-10-27 16:35:44 +01:00
|
|
|
.. option:: -H, --header=<HEADER>
|
|
|
|
|
|
|
|
Add/Override a header to the requests.
|
|
|
|
|
2015-07-11 05:45:23 +02:00
|
|
|
.. option:: --ciphers=<SUITE>
|
|
|
|
|
|
|
|
Set allowed cipher list. The format of the string is
|
|
|
|
described in OpenSSL ciphers(1).
|
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
.. option:: -p, --no-tls-proto=<PROTOID>
|
|
|
|
|
2015-01-15 16:10:16 +01:00
|
|
|
Specify ALPN identifier of the protocol to be used when
|
|
|
|
accessing http URI without SSL/TLS.
|
2015-05-15 17:10:41 +02:00
|
|
|
Available protocols: spdy/2, spdy/3, spdy/3.1 and h2c
|
2015-01-09 16:37:42 +01:00
|
|
|
|
2015-05-15 17:10:41 +02:00
|
|
|
Default: ``h2c``
|
2014-07-08 17:38:43 +02:00
|
|
|
|
2015-07-28 17:01:12 +02:00
|
|
|
.. option:: -d, --data=<PATH>
|
2015-03-26 16:37:12 +01:00
|
|
|
|
|
|
|
Post FILE to server. The request method is changed to
|
|
|
|
POST.
|
|
|
|
|
2015-07-28 17:01:12 +02:00
|
|
|
.. option:: -r, --rate=<N>
|
|
|
|
|
2015-08-08 18:13:35 +02:00
|
|
|
Specifies the fixed rate at which connections are
|
2015-07-28 17:01:12 +02:00
|
|
|
created. The rate must be a positive integer,
|
|
|
|
representing the number of connections to be made per
|
|
|
|
second. When the rate is 0, the program will run as it
|
|
|
|
normally does, creating connections at whatever variable
|
|
|
|
rate it wants. The default value for this option is 0.
|
|
|
|
|
|
|
|
.. option:: -C, --num-conns=<N>
|
|
|
|
|
|
|
|
Specifies the total number of connections to create.
|
|
|
|
The total number of connections must be a positive
|
|
|
|
integer. On each connection, :option:`-m` requests are made. The
|
2015-08-08 18:13:35 +02:00
|
|
|
test stops once as soon as the <N> connections have
|
|
|
|
either completed or failed. When the number of
|
|
|
|
connections is 0, the program will run as it normally
|
|
|
|
does, creating as many connections as it needs in order
|
|
|
|
to make the :option:`-n` requests specified. The default value
|
|
|
|
for this option is 0. The :option:`-n` option is not required if
|
|
|
|
the :option:`-C` option is being used.
|
2015-07-28 17:01:12 +02:00
|
|
|
|
2015-08-29 17:24:11 +02:00
|
|
|
.. option:: -T, --connection-active-timeout=<N>
|
|
|
|
|
|
|
|
Specifies the maximum time that h2load is willing to
|
|
|
|
keep a connection open, regardless of the activity on
|
|
|
|
said connection. <N> must be a positive integer,
|
|
|
|
specifying the number of seconds to wait. When no
|
|
|
|
timeout value is set (either active or inactive), h2load
|
|
|
|
will keep a connection open indefinitely, waiting for a
|
|
|
|
response.
|
|
|
|
|
|
|
|
.. option:: -N, --connection-inactivity-timeout=<N>
|
|
|
|
|
|
|
|
Specifies the amount of time that h2load is willing to
|
|
|
|
wait to see activity on a given connection. <N> must be
|
|
|
|
a positive integer, specifying the number of seconds to
|
|
|
|
wait. When no timeout value is set (either active or
|
|
|
|
inactive), h2load will keep a connection open
|
|
|
|
indefinitely, waiting for a response.
|
|
|
|
|
|
|
|
.. option:: --timing-script-file=<PATH>
|
|
|
|
|
|
|
|
Path of a file containing one or more lines separated by
|
|
|
|
EOLs. Each script line is composed of two tab-separated
|
|
|
|
fields. The first field represents the time offset from
|
2015-09-06 10:41:37 +02:00
|
|
|
the start of execution, expressed as a positive value of
|
|
|
|
milliseconds with microsecond resolution. The second
|
|
|
|
field represents the URI. This option will disable URIs
|
|
|
|
getting from command-line. If '-' is given as <PATH>,
|
|
|
|
script lines will be read from stdin. Script lines are
|
|
|
|
used in order for each client. If :option:`-n` is given, it must be
|
|
|
|
less than or equal to the number of script lines, larger
|
|
|
|
values are clamped to the number of script lines. If :option:`-n`
|
|
|
|
is not given, the number of requests will default to the
|
2015-08-29 17:24:11 +02:00
|
|
|
number of script lines. The scheme, host and port defined
|
|
|
|
in the first URI are used solely. Values contained in
|
|
|
|
other URIs, if present, are ignored. Definition of a
|
|
|
|
base URI overrides all scheme, host or port values.
|
|
|
|
|
|
|
|
.. option:: -B, --base-uri=<URI>
|
|
|
|
|
|
|
|
Specify URI from which the scheme, host and port will be
|
|
|
|
used for all requests. The base URI overrides all
|
|
|
|
values defined either at the command line or inside
|
|
|
|
input files.
|
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
.. option:: -v, --verbose
|
|
|
|
|
|
|
|
Output debug information.
|
|
|
|
|
|
|
|
.. option:: --version
|
|
|
|
|
|
|
|
Display version information and exit.
|
|
|
|
|
|
|
|
.. option:: -h, --help
|
|
|
|
|
|
|
|
Display this help and exit.
|
|
|
|
|
2015-02-01 10:19:16 +01:00
|
|
|
OUTPUT
|
|
|
|
------
|
|
|
|
|
|
|
|
requests
|
|
|
|
total
|
|
|
|
The number of requests h2load was instructed to make.
|
|
|
|
started
|
|
|
|
The number of requests h2load has started.
|
|
|
|
done
|
|
|
|
The number of requests completed.
|
|
|
|
succeeded
|
|
|
|
The number of requests completed successfully. Only HTTP status
|
|
|
|
code 2xx or3xx are considered as success.
|
|
|
|
failed
|
|
|
|
The number of requests failed, including HTTP level failures
|
|
|
|
(non-successful HTTP status code).
|
|
|
|
errored
|
|
|
|
The number of requests failed, except for HTTP level failures.
|
2015-08-14 16:59:47 +02:00
|
|
|
This is the subset of the number reported in ``failed`` and most
|
|
|
|
likely the network level failures or stream was reset by
|
|
|
|
RST_STREAM.
|
2015-08-29 17:24:11 +02:00
|
|
|
timeout
|
|
|
|
The number of requests whose connection timed out before they were
|
|
|
|
completed. This is the subset of the number reported in
|
|
|
|
``errored``.
|
2015-02-01 10:19:16 +01:00
|
|
|
|
|
|
|
status codes
|
|
|
|
The number of status code h2load received.
|
|
|
|
|
|
|
|
traffic
|
|
|
|
total
|
|
|
|
The number of bytes received from the server "on the wire". If
|
|
|
|
requests were made via TLS, this value is the number of decrpyted
|
|
|
|
bytes.
|
|
|
|
headers
|
|
|
|
The number of response header bytes from the server without
|
|
|
|
decompression. For HTTP/2, this is the sum of the payload of
|
|
|
|
HEADERS frame. For SPDY, this is the sum of the payload of
|
|
|
|
SYN_REPLY frame.
|
|
|
|
data
|
|
|
|
The number of response body bytes received from the server.
|
|
|
|
|
|
|
|
time for request
|
|
|
|
min
|
|
|
|
The minimum time taken for request and response.
|
|
|
|
max
|
|
|
|
The maximum time taken for request and response.
|
|
|
|
mean
|
|
|
|
The mean time taken for request and response.
|
|
|
|
sd
|
2015-05-07 13:55:10 +02:00
|
|
|
The standard deviation of the time taken for request and response.
|
2015-02-01 10:19:16 +01:00
|
|
|
+/- sd
|
|
|
|
The fraction of the number of requests within standard deviation
|
|
|
|
range (mean +/- sd) against total number of successful requests.
|
|
|
|
|
2015-05-07 13:55:10 +02:00
|
|
|
time for connect
|
|
|
|
min
|
|
|
|
The minimum time taken to connect to a server.
|
|
|
|
max
|
|
|
|
The maximum time taken to connect to a server.
|
|
|
|
mean
|
|
|
|
The mean time taken to connect to a server.
|
|
|
|
sd
|
|
|
|
The standard deviation of the time taken to connect to a server.
|
|
|
|
+/- sd
|
|
|
|
The fraction of the number of connections within standard
|
|
|
|
deviation range (mean +/- sd) against total number of successful
|
|
|
|
connections.
|
|
|
|
|
|
|
|
time for 1st byte (of (decrypted in case of TLS) application data)
|
|
|
|
min
|
|
|
|
The minimum time taken to get 1st byte from a server.
|
|
|
|
max
|
|
|
|
The maximum time taken to get 1st byte from a server.
|
|
|
|
mean
|
|
|
|
The mean time taken to get 1st byte from a server.
|
|
|
|
sd
|
|
|
|
The standard deviation of the time taken to get 1st byte from a
|
|
|
|
server.
|
|
|
|
+/- sd
|
|
|
|
The fraction of the number of connections within standard
|
|
|
|
deviation range (mean +/- sd) against total number of successful
|
|
|
|
connections.
|
|
|
|
|
2015-04-27 15:36:34 +02:00
|
|
|
FLOW CONTROL
|
|
|
|
------------
|
|
|
|
|
|
|
|
h2load sets large flow control window by default, and effectively
|
|
|
|
disables flow control to avoid under utilization of server
|
|
|
|
performance. To set smaller flow control window, use :option:`-w` and
|
|
|
|
:option:`-W` options. For example, use ``-w16 -W16`` to set default
|
|
|
|
window size described in HTTP/2 and SPDY protocol specification.
|
|
|
|
|
2014-07-08 17:38:43 +02:00
|
|
|
SEE ALSO
|
|
|
|
--------
|
|
|
|
|
2015-01-09 16:37:42 +01:00
|
|
|
:manpage:`nghttp(1)`, :manpage:`nghttpd(1)`, :manpage:`nghttpx(1)`
|