Tcpreplay is a suite of GPLv3 licensed tools for UNIX (and Win32 under Cygwin) operating systems which gives you the ability to use previously captured traffic in libpcap format to test a variety of network devices. It allows you to classify traffic as client or server, rewrite Layer 2, 3 and 4 headers and finally replay the traffic back onto the network and through other devices such as switches, routers, firewalls, NIDS and IPS's. Tcpreplay supports both single and dual NIC modes for testing both sniffing and inline devices.
Tcpreplay is used by numerous firewall, IDS, IPS and other networking vendors, enterprises, universities, labs and open source projects. If your organization uses Tcpreplay, please let me know who you are and what you use it for so that I can continue to add features which are useful.
Version 3.5 introduces features that significantly enhances performance. For example, stock Intel 10GigE adapters with netmap modified drivers and commodity hardware are consistently achieving full wire rates and greater than 100,000 flows/second.
The Tcpreplay suite includes the following tools:
- tcpreplay - replays pcap files at arbitrary speeds onto the network with an option to replay with random IP addresses
- tcpreplay-edit - replays pcap files at arbitrary speeds onto the network with numerous options to modify packets packets on the fly
- tcpliveplay - replays TCP network traffic stored in a pcap file on live networks in a manner that a remote server will respond to
- tcpprep - multi-pass pcap file pre-processor which determines packets as client or server and splits them into creates output files for use by tcpreplay and tcprewrite
- tcprewrite - pcap file editor which rewrites TCP/IP and Layer 2 packet headers
- tcpbridge - bridge two network segments with the power of tcprewrite
- tcpcapinfo - raw pcap file decoder and debugger
Please visit our wiki.
Select the TAR or ZIP to download. Detailed installation instructions are available in the INSTALL document in the tar ball.
./configure
make
sudo make install
This feature will detect netmap capable network drivers on Linux and BSD systems. If detected, the network driver is bypassed for the execution duration of tcpreplay and tcpreplay-edit, and network buffers will be written to directly. This will allow you to achieve full line rates on commodity network adapters, similar to rates achieved by commercial network traffic generators.
Note that bypassing the network driver will disrupt other applications connected through the test interface. Don't test on the same interface you ssh'ed into.
Download latest and install netmap from http://info.iet.unipi.it/~luigi/netmap/ If you extracted netmap into /usr/src/ or /usr/local/src you can build normally. Otherwise you will have to specify the netmap source directory, for example:
./configure --with-netmap=/home/fklassen/git/netmap
make
sudo make install
If you have a question or think you are experiencing a bug, submit them here. It is important that you provide enough information for us to help you.
If your problem has to do with COMPILING tcpreplay:
- Version of tcpreplay you are trying to compile
- Platform (Red Hat Linux 9 on x86, Solaris 7 on SPARC, OS X on PPC, etc)
- Contents of config.status
- Output from configure and make
- Any additional information you think that would be useful.
If your problem has to do with RUNNING tcpreplay or one of the sub-tools:
- Version information (output of -V)
- Command line used (options and arguments)
- Platform (Red Hat Linux 9 on Intel, Solaris 7 on SPARC, etc)
- Make & model of the network card(s) and driver(s) version
- Error message (if available) and/or description of problem
- If possible, attach the pcap file used (compressed with bzip2 or gzip preferred)
- The core dump or backtrace if available
- Detailed description of your problem or what you are trying to accomplish
Note: The author of tcpreplay primarily uses OS X and Linux; hence, if you're reporting an issue on another platform, it is important that you give very detailed information as I may not be able to reproduce your issue.
You are also strongly encouraged to read the extensive documentation (man pages, FAQ, documents in /docs and email list archives) BEFORE posting to the tcpreplay-users email list:
http://lists.sourceforge.net/lists/listinfo/tcpreplay-users
Lastly, please don't email the author directly with your questions. Doing so prevents others from potentially helping you and your question/answer from showing up in the list archives.
Tcpreplay 3.5 is GPLv3 and includes software developed by the University of California, Berkeley, Lawrence Berkeley Laboratory and its contributors.
Tcpreplay is authored by Aaron Turner(@synfinatic). In 2013 Fred Klassen (@fklassen), Founder and VP Network Technology, AppNeta Inc. added performance features and enhancements, and ultimately took over the maintenance of Tcpreplay.
The source code repository has moved to GitHub. You can get a working copy of the repository by installing git and executing:
git clone [email protected]:appneta/tcpreplay.git
However you will find that you will not be able to contribute to the Tcpreplay project directly if you use this method. If you believe that you may someday contribute to the repository, GitHub provides an innovative approach. Forking the @appneta/tcpreplay repository allows you to work on your own copy of the repository and submit code changes without first asking permission from the authors:
- if you haven't already done so, get yourself a free GitHub ID and visit @appneta/tcpreplay
- click the Fork button to get your own private copy of the repository
- on your build system clone your private repository:
git clone [email protected]:<your ID>/tcpreplay.git
- we like to keep the master branch available for projection ready code so we recommend that you make a branch fore each feature or bug fix
- when you are happy with your work, push it to your GitHub repository
- on your GitHub repository select your new branch and submit a Pull Request to master
- optionally monitor the status of your submission here
We will review and possibly discuss the changes with you through GitHub services. If we accept the submission, it will instantly be applied to the production master branch.
Please visit our wiki.