perfdhcp(8)

NAME

   perfdhcp - DHCP benchmarking tool

SYNOPSIS

   perfdhcp [-1] [-4|-6] [-A encapsulation-level] [-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]
            [-M mac-list-file] [-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.

   -f renew-rate
       Rate at which DHCPv4 or DHCPv6 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.

   -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.

   -M mac-list-file
       A text file containing a list of MAC addresses, one per line. If
       provided, a MAC address will be choosen randomly from this list for
       every new exchange. In the DHCPv6 case, MAC addresses are used to
       generate DUID-LLs. This parameter must not be used in conjunction
       with the -b parameter.

   -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 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.

   -A encapsulation-level
       Specifies that relayed traffic must be generated. The argument
       specifies the level of encapsulation, i.e. how many relay agents
       are simulated. Currently the only supported encapsulation-level
       value is 1, which means that the generated traffic is an equivalent
       of the traffic passing through a single relay agent.

   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.

MAILING LISTS AND SUPPORT

   There are two mailing lists available for Kea project. kea-users
   (kea-users at lists.isc.org) is intended for Kea users, while kea-dev
   (kea-dev at lists.isc.org) is intended for Kea developers, prospective
   contributors and other advanced users. Both lists are available at
   http://lists.isc.org. The community provides best effort type of
   support on both of those lists.

   ISC provides professional support for Kea services. See
   https://www.isc.org/kea/ for details.

HISTORY

   The perfdhcp tool was initially coded in October 2011 by John DuBois,
   Francis Dupont and Marcin Siodelski of ISC. Kea 1.0.0 that included
   perfdhcp was released in December 2015.

SEE ALSO

   kea-dhcp4(8), kea-dhcp6(8), kea-dhcp-ddns(8), kea-admin(8), keactrl(8),
   kea-lfc(8), Kea Administrator's Guide.

AUTHOR

   The Kea software has been written by a number of engineers working for
   ISC: Tomek Mrugalski, Stephen Morris, Marcin Siodelski, Thomas
   Markwalder, Francis Dupont, Jeremy C. Reed, Wlodek Wencel and Shawn
   Routhier. That list is roughly in the chronological order in which the
   authors made their first contribution. For a complete list of authors
   and contributors, see AUTHORS file.

COPYRIGHT

   Copyright  2016 Internet Systems Consortium, Inc. ("ISC")



Opportunity


Personal Opportunity - Free software gives you access to billions of dollars of software at no cost. Use this software for your business, personal use or to develop a profitable skill. Access to source code provides access to a level of capabilities/information that companies protect though copyrights. Open source is a core component of the Internet and it is available to you. Leverage the billions of dollars in resources and capabilities to build a career, establish a business or change the world. The potential is endless for those who understand the opportunity.

Business Opportunity - Goldman Sachs, IBM and countless large corporations are leveraging open source to reduce costs, develop products and increase their bottom lines. Learn what these companies know about open source and how open source can give you the advantage.


Free Software


Free Software provides computer programs and capabilities at no cost but more importantly, it provides the freedom to run, edit, contribute to, and share the software. The importance of free software is a matter of access, not price. Software at no cost is a benefit but ownership rights to the software and source code is far more significant.

Free Office Software - The Libre Office suite provides top desktop productivity tools for free. This includes, a word processor, spreadsheet, presentation engine, drawing and flowcharting, database and math applications. Libre Office is available for Linux or Windows.


Free Books


The Free Books Library is a collection of thousands of the most popular public domain books in an online readable format. The collection includes great classical literature and more recent works where the U.S. copyright has expired. These books are yours to read and use without restrictions.

Source Code - Want to change a program or know how it works? Open Source provides the source code for its programs so that anyone can use, modify or learn how to write those programs themselves. Visit the GNU source code repositories to download the source.


Education


Study at Harvard, Stanford or MIT - Open edX provides free online courses from Harvard, MIT, Columbia, UC Berkeley and other top Universities. Hundreds of courses for almost all major subjects and course levels. Open edx also offers some paid courses and selected certifications.

Linux Manual Pages - A man or manual page is a form of software documentation found on Linux/Unix operating systems. Topics covered include computer programs (including library and system calls), formal standards and conventions, and even abstract concepts.