Provided by: kea-admin_1.0.0-1build1_amd64 

NAME
perfdhcp - DHCP benchmarking tool
SYNOPSIS
perfdhcp [-1] [-4|-6] [-a aggressivity] [-b base] [-B] [-c] [-d drop-time] [-D max-drop] [-e lease-type]
[-E time-offset] [-f renew-rate] [-F release-rate] [-h] [-i] [-I ip-offset]
[-l local-address|interface] [-L local-port] [-n num-request] [-O random-offset]
[-p test-period] [-P preload] [-r rate] [-R num-clients] [-s seed] [-S srvid-offset] [-t report]
[-T template-file] [-v] [-W wrapped] [-x diagnostic-selector] [-X xid-offset] [server]
DESCRIPTION
perfdhcp is a DHCP benchmarking tool. It provides a way of measuring the performance of DHCP servers by
generating large amounts of traffic from simulated multiple clients. It is able to test both IPv4 and
IPv6 servers, and provides statistics concerning response times and the number of requests that are
dropped.
By default, tests are run using the full four-packet exchange sequence (DORA for DHCPv4, SARR for
DHCPv6). An option is provided to run tests using the initial two-packet exchange (DO and SA) instead. It
is also possible to configure perfdhcp to send DHCPv6 RENEW and RELEASE messages at a specified rate in
parallel with the DHCPv6 four-way exchanges.
When running a performance test, perfdhcp will exchange packets with the server under test as fast as
possible unless the -r is given to limit the request rate. The length of the test can be limited by
setting a threshold on any or all of the number of requests made by perfdhcp, the elapsed time, or the
number of requests dropped by the server.
TEMPLATES
To allow the contents of packets sent to the server to be customized, perfdhcp allows the specification
of template files that determine the contents of the packets. For example, the customized packet may
contain a DHCPv6 ORO to request a set of options to be returned by the server, or it may contain the
Client FQDN option to request that server performs DNS updates. This may be used to discover performance
bottlenecks for different server configurations (e.g. DDNS enabled or disabled).
Up to two template files can be specified on the command line, each file representing the contents of a
particular type of packet, the type being determined by the test being carried out. For example, if
testing DHCPv6:
• With no template files specified on the command line, perfdhcp will generate both SOLICIT and REQUEST
packets.
• With one template file specified, that file will be used as the pattern for SOLICIT packets: perfdhcp
will generate the REQUEST packets.
• With two template files given on the command line, the first will be used as the pattern for SOLICIT
packets, the second as the pattern for REQUEST packets.
(Similar determination applies to DHCPv4's DISCOVER and REQUEST packets.)
The template file holds the DHCP packet represented as a stream of ASCII hexadecimal digits and it
excludes any IP/UDP stack headers. The template file must not contain any characters other than
hexadecimal digits and spaces. Spaces are discarded when the template file is parsed (so in the file,
'12B4' is the same as '12 B4' which is the same as '1 2 B 4')
The template files should be used in conjunction with the command line parameters which specify offsets
of the data fields being modified in outbound packets. For example, the -E time-offset switch specifies
the offset of the DHCPv6 Elapsed Time option in the packet template. If the offset is specified, perfdhcp
will inject the current elapsed time value into this field before sending the packet to the server.
In many scenarios, perfdhcp needs to simulate multiple clients (having unique client identifier). Since
packets for each client are generated from the same template file, it is necessary to randomize the
client identifier (or HW address in DHCPv4) in the packet created from it. The -O random-offset option
allows specification of the offset in the template where randomization should be performed. It is
important to note that this offset points to the end (not the beginning) of the client identifier (or HW
address field). The number of bytes being randomized depends on the number of simulated clients. If the
number of simulated clients is between 1 and 255, only one byte (to which randomization offset points)
will be randomized. If the number of simulated clients is between 256 and 65535, two bytes will be
randomized. Note, that two last bytes of the client identifier will be randomized in this case: the byte
which randomization offset parameter points to, and the one which precedes it (random-offset - 1). If the
number of simulated clients exceeds 65535, three bytes will be randomized; and so on.
Templates may be currently used to generate packets being sent to the server in 4-way exchanges, i.e.
SOLICIT, REQUEST (DHCPv6) and DISCOVER, REQUEST (DHCPv4). They cannot be used when RENEW or RELEASE
packets are being sent.
OPTIONS
-1
Take the server-ID option from the first received message.
-4
DHCPv4 operation; this is the default. It is incompatible with the -6 option.
-6
DHCPv6 operation. This is incompatible with the -4 option.
-a aggressivity
When the target sending rate is not yet reached, control how many exchanges are initiated before the
next pause. This is a positive integer and defaults to 1.
-b basetype=value
The base MAC or DUID used to simulate different clients. The basetype may be "mac" or "duid". (The
keyword "ether" may alternatively used for MAC.) The -b option can be specified multiple times. The
MAC address must consist of six octets separated by single (:) or double (::) colons, for example:
mac=00:0c:01:02:03:04. The DUID value is a hexadecimal string: it must be at least six octets long
and must not be longer than 64 bytes and the length must be less than 128 hexadecimal digits, for
example: duid=0101010101010101010110111F14.
-d drop-time
Specify the time after which a request is treated as having been lost. The value is given in seconds
and may contain a fractional component. The default is 1 second.
-e lease-type
Specifies the type of lease being requested from the server. It may be one of the following:
address-only
Only regular addresses (v4 or v6) will be requested.
prefix-only
Only IPv6 prefixes will be requested.
address-and-prefix
Both IPv6 addresses and prefixes will be requested.
The -e prefix-only and -e address-and-prefix forms may not be used with the -4 option.
-h
Print help and exit.
-i
Do only the initial part of the exchange: DISCOVER-OFFER if -4 is selected, SOLICIT-ADVERTISE if -6
is chosen.
-i is incompatible with the following options: -1, -d, -D, -E, -S, -I and -F. In addition, it cannot
be used with multiple instances of -O, -T and -X.
-l local-addr|interface
For DHCPv4 operation, specify the local hostname/address to use when communicating with the server.
By default, the interface address through which traffic would normally be routed to the server is
used. For DHCPv6 operation, specify the name of the network interface through which exchanges are
initiated.
-L local-port
Specify the local port to use. This must be zero or a positive integer up to 65535. A value of 0 (the
default) allows perfdhcp to choose its own port.
-P preload
Initiate preload exchanges back to back at startup. preload must be 0 (the default) or a positive
integer.
-r rate
Initiate rate DORA/SARR (or if -i is given, DO/SA) exchanges per second. A periodic report is
generated showing the number of exchanges which were not completed, as well as the average response
latency. The program continues until interrupted, at which point a final report is generated.
-R num-clients
Specify how many different clients are used. With a value of 1 (the default), all requests seem to
come from the same client. num-clients must be a positive number.
-s seed
Specify the seed for randomization, making runs of perfdhcp repeatable. seed is 0 or a positive
integer. The value 0 means that a seed is not used; this is the default.
-T template-file
The name of a file containing the template to use as a stream of hexadecimal digits. This may be
specified up to two times and controls the contents of the packets sent (see the "TEMPLATES" section
above).
-v
Print the version of this program.
-w wrapped
Command to call with a single parameter of "start" or "stop" at the beginning/end of the program.
-x diagnostic-selector
Include extended diagnostics in the output. diagnostic-selector is a string of single-keywords
specifying the operations for which verbose output is desired. The selector key letters are:
a
Print the decoded command line arguments.
e
Print the exit reason.
i
Print rate processing details.
s
Print the first server-ID.
t
When finished, print timers of all successful exchanges.
T
When finished, print templates
DHCPv4-Only Options
The following options only apply for DHCPv4 (i.e. when -4 is given).
-B
Force broadcast handling.
DHCPv6-Only Options
The following options only apply for DHCPv6 (i.e. when -6 is given).
-c
Add a rapid commit option (exchanges will be SOLICIT-ADVERTISE).
-f renew-rate
Rate at which IPv6 RENEW requests are sent to a server. This value is only valid when used in
conjunction with the exchange rate (given by -r rate). Furthermore the sum of this value and the
release-rate (given by -F rate) must be equal to or less than the exchange rate.
-F release-rate
Rate at which IPv6 RELEASE requests are sent to a server. This value is only valid when used in
conjunction with the exchange rate (given by -r rate). Furthermore the sum of this value and the
renew-rate (given by -f rate) must be equal to or less than the exchange rate.
Template-Related Options
The following options may only be used in conjunction with -T and control how perfdhcp modifies the
template. The options may be specified multiple times on the command line; each occurrence affects the
corresponding template file (see "TEMPLATES" above).
-E time-offset
Offset of the (DHCPv4) secs field or (DHCPv6) elapsed-time option in the (second i.e. REQUEST)
template and must be 0 or a positive integer: a value of 0 disables this.
-I ip-offset
Offset of the (DHCPv4) IP address in the requested-IP option / (DHCPv6) IA_NA option in the
(second/request) template.
-O random-offset
Offset of the last octet to randomize in the template. random-offset must be an integer greater than
3. The -T switch must be given to use this option.
-S srvid-offset
Offset of the server-ID option in the (second/request) template. srvid-offset must be a positive
integer, and the switch can only be used when the template option (-T) is also given.
-X xid-offset
Offset of the transaction ID (xid) in the template. xid-offset must be a positive integer, and the
switch can only be used when the template option (-T) is also given.
Options Controlling a Test
The following options may only be used in conjunction with -r and control both the length of the test and
the frequency of reports.
-D max-drop
Abort the test if more than max-drop requests have been dropped. Use -D 0 to abort if even a single
request has been dropped. If max-drop includes the suffix '%', it specifies a maximum percentage of
requests that may be dropped before abort. In this case, testing of the threshold begins after 10
requests have been expected to be received.
-n num-requests
Initiate num-request transactions. No report is generated until all transactions have been
initiated/waited-for, after which a report is generated and the program terminates.
-p test-period
Send requests for test-period, which is specified in the same manner as -d. This can be used as an
alternative to -n, or both options can be given, in which case the testing is completed when either
limit is reached.
-t interval
Sets the delay (in seconds) between two successive reports.
Arguments
server
Server to test, specified as an IP address. In the DHCPv6 case, the special name 'all' can be used to
refer to All_DHCP_Relay_Agents_and_Servers (the multicast address FF02::1:2), or the special name
'servers' to refer to All_DHCP_Servers (the multicast address FF05::1:3). The server is mandatory
except where the -l option is given to specify an interface, in which case it defaults to 'all'.
ERRORS
perfdhcp can report the following errors in the packet exchange:
tooshort
A message was received that was too short.
orphans
Received a message which doesn't match one sent to the server (i.e. it is a duplicate message, a
message that has arrived after an excessive delay, or one that is just not recognized).
locallimit
Reached local system limits when sending a message.
EXIT STATUS
perfdhcp can exit with one of the following status codes:
0
Success.
1
General error.
2
Error in command-line arguments.
3
No general failures in operation, but one or more exchanges were unsuccessful.
SEE ALSO
dhcpd(8), kea-dhcp4(8), kea-dhcp6(8), Kea Administrator Guide.
COPYRIGHT
Copyright © 2014 Internet Systems Consortium, Inc. ("ISC")
Kea February 19, 2014 PERFDHCP(8)