=head1 NAME dumpcap - Dump network traffic =head1 SYNOPSIS B S<[ B<-a> Ecapture autostop conditionE ] ...> S<[ B<-b> Ecapture ring buffer optionE] ...> S<[ B<-B> Ecapture buffer sizeE ] > S<[ B<-c> Ecapture packet countE ]> S<[ B<-d> ]> S<[ B<-D> ]> S<[ B<-f> Ecapture filterE ]> S<[ B<-h> ]> S<[ B<-i> Ecapture interfaceE|- ]> S<[ B<-I> ]> S<[ B<-L> ]> S<[ B<-M> ]> S<[ B<-n> ]> S<[ B<-p> ]> S<[ B<-P> ]> S<[ B<-q> ]> S<[ B<-s> Ecapture snaplenE ]> S<[ B<-S> ]> S<[ B<-v> ]> S<[ B<-w> EoutfileE ]> S<[ B<-y> Ecapture link typeE ]> =head1 DESCRIPTION B is a network traffic dump tool. It lets you capture packet data from a live network and write the packets to a file. B's native capture file format is B format, which is also the format used by B, B and various other tools. When the B<-n> option is specified, the output file is written in the new B format. Without any options set it will use the pcap library to capture traffic from the first available network interface and writes the received raw packet data, along with the packets' time stamps into a libpcap file. If the B<-w> option is not specified, B writes to a newly created libpcap file with a randomly chosen name. If the B<-w> option is specified, B writes to the file specified by that option. Packet capturing is performed with the pcap library. The capture filter syntax follows the rules of the pcap library. =head1 OPTIONS =over 4 =item -a Ecapture autostop conditionE Specify a criterion that specifies when B is to stop writing to a capture file. The criterion is of the form IB<:>I, where I is one of: B:I Stop writing to a capture file after I seconds have elapsed. B:I Stop writing to a capture file after it reaches a size of I kilobytes (where a kilobyte is 1024 bytes). If this option is used together with the -b option, dumpcap will stop writing to the current capture file and switch to the next one if filesize is reached. B:I Stop writing to capture files after I number of files were written. =item -b Ecapture ring buffer optionE Cause B to run in "multiple files" mode. In "multiple files" mode, B will write to several capture files. When the first capture file fills up, B will switch writing to the next file and so on. The created filenames are based on the filename given with the B<-w> option, the number of the file and on the creation date and time, e.g. outfile_00001_20050604120117.pcap, outfile_00002_20050604120523.pcap, ... With the I option it's also possible to form a "ring buffer". This will fill up new files until the number of files specified, at which point B will discard the data in the first file and start writing to that file and so on. If the I option is not set, new files filled up until one of the capture stop conditions match (or until the disk is full). The criterion is of the form IB<:>I, where I is one of: B:I switch to the next file after I seconds have elapsed, even if the current file is not completely filled up. B:I switch to the next file after it reaches a size of I kilobytes (where a kilobyte is 1024 bytes). B:I begin again with the first file after I number of files were written (form a ring buffer). This value must be less than 100000. Caution should be used when using large numbers of files: some filesystems do not handle many files in a single directory well. The B criterion requires either B or B to be specified to control when to go to the next file. It should be noted that each B<-b> parameter takes exactly one criterion; to specify two criterion, each must be preceded by the B<-b> option. Example: B<-b filesize:1024 -b files:5> results in a ring buffer of five files of size one megabyte. =item -B Ecapture buffer sizeE Set capture buffer size (in MB, default is 1MB). This is used by the the capture driver to buffer packet data until that data can be written to disk. If you encounter packet drops while capturing, try to increase this size. Note that, while B attempts to set the buffer size to 1MB by default, and can be told to set it to a larger value, the system or interface on which you're capturing might silently limit the capture buffer size to a lower value or raise it to a higher value. This is available on UNIX systems with libpcap 1.0.0 or later and on Windows. It is not available on UNIX systems with earlier versions of libpcap. This option can occur multiple times. If used before the first occurrence of the B<-i> option, it sets the default capture buffer size. If used after an B<-i> option, it sets the capture buffer size for the interface specified by the last B<-i> option occurring before this option. If the capture buffer size is not set specifically, the default capture buffer size is used if provided. =item -c Ecapture packet countE Set the maximum number of packets to read when capturing live data. =item -d Dump the code generated for the capture filter in a human-readable form, and exit. =item -D Print a list of the interfaces on which B can capture, and exit. For each network interface, a number and an interface name, possibly followed by a text description of the interface, is printed. The interface name or the number can be supplied to the B<-i> option to specify an interface on which to capture. This can be useful on systems that don't have a command to list them (e.g., Windows systems, or UNIX systems lacking B); the number can be useful on Windows 2000 and later systems, where the interface name is a somewhat complex string. Note that "can capture" means that B was able to open that device to do a live capture. Depending on your system you may need to run dumpcap from an account with special privileges (for example, as root) to be able to capture network traffic. If "B" is not run from such an account, it will not list any interfaces. =item -f Ecapture filterE Set the capture filter expression. The entire filter expression must be specified as a single argument (which means that if it contains spaces, it must be quoted). This option can occur multiple times. If used before the first occurrence of the B<-i> option, it sets the default capture filter expression. If used after an B<-i> option, it sets the capture filter expression for the interface specified by the last B<-i> option occurring before this option. If the capture filter expression is not set specifically, the default capture filter expression is used if provided. =item -h Print the version and options and exits. =item -i Ecapture interfaceE|- Set the name of the network interface or pipe to use for live packet capture. Network interface names should match one of the names listed in "B" (described above); a number, as reported by "B", can also be used. If you're using UNIX, "B" or "B" might also work to list interface names, although not all versions of UNIX support the B<-a> option to B. If no interface is specified, B searches the list of interfaces, choosing the first non-loopback interface if there are any non-loopback interfaces, and choosing the first loopback interface if there are no non-loopback interfaces. If there are no interfaces at all, B reports an error and doesn't start the capture. Pipe names should be either the name of a FIFO (named pipe) or ``-'' to read data from the standard input. Data read from pipes must be in standard libpcap format. This option can occur multiple times. When capturing from multiple interfaces, the capture file will be saved in pcap-ng format. Note: the Win32 version of B doesn't support capturing from pipes or stdin! =item -I Put the interface in "monitor mode"; this is supported only on IEEE 802.11 Wi-Fi interfaces, and supported only on some operating systems. Note that in monitor mode the adapter might disassociate from the network with which it's associated, so that you will not be able to use any wireless networks with that adapter. This could prevent accessing files on a network server, or resolving host names or network addresses, if you are capturing in monitor mode and are not connected to another network with another adapter. This option can occur multiple times. If used before the first occurrence of the B<-i> option, it enables the monitor mode for all interfaces. If used after an B<-i> option, it enables the monitor mode for the interface specified by the last B<-i> option occurring before this option. =item -L List the data link types supported by the interface and exit. The reported link types can be used for the B<-y> option. =item -M When used with B<-D>, B<-L> or B<-S>, print machine-readable output. The machine-readable output is intended to be read by B and B; its format is subject to change from release to release. =item -n Save files as pcap-ng. This is the default. =item -p I put the interface into promiscuous mode. Note that the interface might be in promiscuous mode for some other reason; hence, B<-p> cannot be used to ensure that the only traffic that is captured is traffic sent to or from the machine on which B is running, broadcast traffic, and multicast traffic to addresses received by that machine. This option can occur multiple times. If used before the first occurrence of the B<-i> option, no interface will be put into the promiscuous mode. If used after an B<-i> option, the interface specified by the last B<-i> option occurring before this option will not be put into the promiscuous mode. =item -P Save files as pcap instead of the default pcap-ng. In situations that require pcap-ng, such as capturing from multiple interfaces, this option will be overridden. =item -q When capturing packets, don't display the continuous count of packets captured that is normally shown when saving a capture to a file; instead, just display, at the end of the capture, a count of packets captured. On systems that support the SIGINFO signal, such as various BSDs, you can cause the current count to be displayed by typing your "status" character (typically control-T, although it might be set to "disabled" by default on at least some BSDs, so you'd have to explicitly set it to use it). =item -s Ecapture snaplenE Set the default snapshot length to use when capturing live data. No more than I bytes of each network packet will be read into memory, or saved to disk. A value of 0 specifies a snapshot length of 65535, so that the full packet is captured; this is the default. This option can occur multiple times. If used before the first occurrence of the B<-i> option, it sets the default snapshot length. If used after an B<-i> option, it sets the snapshot length for the interface specified by the last B<-i> option occurring before this option. If the snapshot length is not set specifically, the default snapshot length is used if provided. =item -S Print statistics for each interface once every second. =item -v Print the version and exit. =item -w EoutfileE Write raw packet data to I. NOTE: The usage of "-" for stdout is not allowed here! =item -y Ecapture link typeE Set the data link type to use while capturing packets. The values reported by B<-L> are the values that can be used. This option can occur multiple times. If used before the first occurrence of the B<-i> option, it sets the default capture link type. If used after an B<-i> option, it sets the capture link type for the interface specified by the last B<-i> option occurring before this option. If the capture link type is not set specifically, the default capture link type is used if provided. =back =head1 CAPTURE FILTER SYNTAX See the manual page of pcap-filter(7) or, if that doesn't exist, tcpdump(8), or, if that doesn't exist, L. =head1 SEE ALSO wireshark(1), tshark(1), editcap(1), mergecap(1), capinfos(1), pcap(3), pcap-filter(7) or tcpdump(8) if it doesn't exist. =head1 NOTES B is part of the B distribution. The latest version of B can be found at L. HTML versions of the Wireshark project man pages are available at: L. =head1 AUTHORS B is derived from the B capturing engine code; see the list of authors in the B man page for a list of authors of that code.