Tcpdump Introductory Guide
Tcpdump is a powerful command-line packet analyzer used for network packet capturing. It allows users to display and capture packets being transmitted or received over a network. Below is a basic guide on how to use tcpdump effectively:
1. Basic Command Structure
- 
Basic Command: tcpdumpThis command will capture packets on the default network interface. 
- 
Specify an Interface: tcpdump -i <interface_name>Example: tcpdump -i eth0
- 
Capture Only a Certain Number of Packets: tcpdump -c <packet_count> -i <interface_name>Example: tcpdump -c 10 -i eth0
2. Basic Filters
- 
Capture Packets from a Specific Host: tcpdump host <ip_address>Example: tcpdump host 192.168.1.1
- 
Capture Packets from a Specific Port: tcpdump port <port_number>Example: tcpdump port 80
- 
Capture Traffic Only from Source or Destination: tcpdump src <ip_address> tcpdump dst <ip_address>
- 
Capture Traffic for a Specific Protocol: tcpdump <protocol>Examples: tcpdump tcp tcpdump udp tcpdump icmp
3. Display Options
- 
Verbose Mode: tcpdump -v tcpdump -vv # More verbose tcpdump -vvv # Most verbose
- 
Print Packet Data in ASCII: tcpdump -A
- 
Print Packet Data in Hex and ASCII: tcpdump -X
- 
Timestamp Options: tcpdump -tttt # Human-readable timestamp
4. Saving and Reading Packet Captures
- 
Save Packets to a File: tcpdump -w <filename>.pcap -i <interface_name>Example: tcpdump -w capture.pcap -i eth0
- 
Read Packets from a File: tcpdump -r <filename>.pcapExample: tcpdump -r capture.pcap
5. Advanced Filters
- 
Capture Packets Based on Network Range: tcpdump net <network>/<CIDR>Example: tcpdump net 192.168.1.0/24
- 
Logical Operators: tcpdump host 192.168.1.1 and port 22 tcpdump host 192.168.1.1 or host 10.0.0.1 tcpdump not port 80
- 
Filter by Packet Size: tcpdump less <size> tcpdump greater <size>
6. Useful Tips and Best Practices
- 
Run as Root/Administrator: tcpdumptypically requires elevated privileges to capture traffic.
- 
Limit Packet Capture Size: Use the -s <snaplen>option to limit the amount of data captured per packet:tcpdump -s 96 -i eth0
- 
Review in Wireshark: Use Wireshark to open .pcapfiles for a more user-friendly analysis.
- 
Filter by Specific Keywords: Apply filters for finer control, e.g., HTTP traffic: tcpdump -i eth0 'tcp port 80 and (((ip[2:2] - ((ip[0]&0xf)<<2)) - ((tcp[12]&0xf0)>>2)) != 0)'
This guide provides you with the foundational steps to start using tcpdump for network analysis and packet capturing.