Duplicate
The following scenarios demonstrate how to configure port
mirroring using the traffic policy duplicate feature.
Port mirroring duplicates network packets and forwards copies
to monitoring destinations while preserving the original traffic flow.
traffic selectors can be used to filter which packets
should be duplicated based on protocol, addresses, or other criteria.
Test duplicate local traffic to an interface
Description
This scenario configures link-level port mirroring on DUT0’s (‘eth0’ interface). Both ingress (link-in) and egress (link-out) traffic policies are applied to duplicate all traffic to another physical interface.
Scenario
Step 1: Set the following configuration in DUT0 :
set interfaces ethernet eth0 address 10.0.0.1/24 set interfaces ethernet eth0 traffic policy link-in DUP_POLICY set interfaces ethernet eth0 traffic policy link-out DUP_POLICY set interfaces ethernet eth2 address 20.0.0.1/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0' set traffic policy DUP_POLICY rule 1 action accept set traffic policy DUP_POLICY rule 1 duplicate device eth2
Step 2: Set the following configuration in DUT1 :
set interfaces ethernet eth0 address 10.0.0.2/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0'
Step 3: Set the following configuration in DUT2 :
set interfaces ethernet eth2 address 20.0.0.2/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0'
Step 4: Ping IP address 10.0.0.1 from DUT1:
admin@DUT1$ ping 10.0.0.1 count 1 size 56 timeout 1Show output
PING 10.0.0.1 (10.0.0.1) 56(84) bytes of data. 64 bytes from 10.0.0.1: icmp_seq=1 ttl=64 time=0.561 ms --- 10.0.0.1 ping statistics --- 1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.561/0.561/0.561/0.000 ms
Step 5: Ping IP address 20.0.0.1 from DUT2:
admin@DUT2$ ping 20.0.0.1 count 1 size 56 timeout 1Show output
PING 20.0.0.1 (20.0.0.1) 56(84) bytes of data. 64 bytes from 20.0.0.1: icmp_seq=1 ttl=64 time=0.384 ms --- 20.0.0.1 ping statistics --- 1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.384/0.384/0.384/0.000 ms
Step 6: Modify the following configuration lines in DUT0 :
set service echo port 5050
Note
Start packet capture on DUT0 eth2 to monitor duplicated traffic
Step 7: Run command monitor test connection client 10.0.0.1 5050 udp at DUT1.
Note
Now it is important to generate some traffic from DUT1 to DUT0 echo service.
Note
Stop packet capture. Expected output:
Show output
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode listening on eth2, link-type EN10MB (Ethernet), snapshot length 262144 bytes 17:55:03.426609 IP 10.0.0.2.43267 > 10.0.0.1.5050: UDP, length 17 17:55:03.427821 IP 10.0.0.1.5050 > 10.0.0.2.43267: UDP, length 17 17:55:04.428058 IP 10.0.0.2.43267 > 10.0.0.1.5050: UDP, length 17 17:55:04.429224 IP 10.0.0.1.5050 > 10.0.0.2.43267: UDP, length 17 17:55:05.429760 IP 10.0.0.2.43267 > 10.0.0.1.5050: UDP, length 17 17:55:05.430957 IP 10.0.0.1.5050 > 10.0.0.2.43267: UDP, length 17 17:55:06.432526 IP 10.0.0.2.43267 > 10.0.0.1.5050: UDP, length 17 17:55:06.434134 IP 10.0.0.1.5050 > 10.0.0.2.43267: UDP, length 17 17:55:07.000514 ARP, Request who-has 20.0.0.2 tell 20.0.0.1, length 28 17:55:07.000523 ARP, Request who-has 10.0.0.2 tell 10.0.0.1, length 28 17:55:07.000779 ARP, Reply 20.0.0.2 is-at de:ad:be:ef:6c:22, length 28 17:55:07.000850 ARP, Reply 10.0.0.2 is-at de:ad:be:ef:6c:10, length 28 17:55:07.434018 IP 10.0.0.2.43267 > 10.0.0.1.5050: UDP, length 17 17:55:07.434971 IP 10.0.0.1.5050 > 10.0.0.2.43267: UDP, length 17 ^C 14 packets captured 14 packets received by filter 0 packets dropped by kernel admin@osdx$
Test duplicate local traffic to a remote IP
Description
This scenario configures remote port mirroring on DUT0 (‘eth0’ interface). Local-in and local-out traffic policies duplicate traffic to a remote IP address. A traffic selector is configured to filter and duplicate only UDP traffic.
Scenario
Step 1: Set the following configuration in DUT0 :
set interfaces ethernet eth0 address 10.0.0.1/24 set interfaces ethernet eth0 traffic policy local-in DUP_POLICY set interfaces ethernet eth0 traffic policy local-out DUP_POLICY set interfaces ethernet eth2 address 20.0.0.1/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0' set traffic policy DUP_POLICY rule 1 action accept set traffic policy DUP_POLICY rule 1 duplicate remote 20.0.0.2 set traffic policy DUP_POLICY rule 1 selector UDP_SEL set traffic selector UDP_SEL rule 1 protocol udp
Step 2: Set the following configuration in DUT1 :
set interfaces ethernet eth0 address 10.0.0.2/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0'
Step 3: Set the following configuration in DUT2 :
set interfaces ethernet eth2 address 20.0.0.2/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0'
Step 4: Ping IP address 10.0.0.1 from DUT1:
admin@DUT1$ ping 10.0.0.1 count 1 size 56 timeout 1Show output
PING 10.0.0.1 (10.0.0.1) 56(84) bytes of data. 64 bytes from 10.0.0.1: icmp_seq=1 ttl=64 time=0.627 ms --- 10.0.0.1 ping statistics --- 1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.627/0.627/0.627/0.000 ms
Step 5: Ping IP address 20.0.0.1 from DUT2:
admin@DUT2$ ping 20.0.0.1 count 1 size 56 timeout 1Show output
PING 20.0.0.1 (20.0.0.1) 56(84) bytes of data. 64 bytes from 20.0.0.1: icmp_seq=1 ttl=64 time=0.376 ms --- 20.0.0.1 ping statistics --- 1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.376/0.376/0.376/0.000 ms
Note
Start packet capture on DUT2 eth2 to monitor duplicated traffic
Step 6: Initiate a tcp connection from DUT1 to DUT0 and try to send some messages between both endpoints
admin@DUT0$ monitor test connection server 5050 tcp admin@DUT1$ monitor test connection client 10.0.0.1 5050 tcp
Step 7: Initiate a udp connection from DUT1 to DUT0 and try to send some messages between both endpoints
admin@DUT0$ monitor test connection server 5050 udp admin@DUT1$ monitor test connection client 10.0.0.1 5050 udp
Note
Stop packet capture. Expected output:
Show output
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode listening on eth2, link-type EN10MB (Ethernet), snapshot length 262144 bytes 17:55:18.199781 IP6 :: > ff02::16: HBH ICMP6, multicast listener report v2, 4 group record(s), length 88 17:55:18.807836 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 4 group record(s), length 88 17:55:18.819747 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 1 group record(s), length 28 17:55:18.963749 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 1 group record(s), length 28 17:55:19.191758 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 4 group record(s), length 88 17:55:22.451890 IP 10.0.0.2.40724 > 10.0.0.1.5050: UDP, length 20 17:55:22.477148 IP 10.0.0.1.5050 > 10.0.0.2.40724: UDP, length 20 17:55:22.508311 IP 10.0.0.2.40724 > 10.0.0.1.5050: UDP, length 20 17:55:22.535969 IP 10.0.0.1.5050 > 10.0.0.2.40724: UDP, length 20 17:55:22.564837 IP 10.0.0.2.40724 > 10.0.0.1.5050: UDP, length 20 17:55:22.592051 IP 10.0.0.1.5050 > 10.0.0.2.40724: UDP, length 20 17:55:22.624565 IP 10.0.0.2.40724 > 10.0.0.1.5050: UDP, length 20 17:55:22.650207 IP 10.0.0.1.5050 > 10.0.0.2.40724: UDP, length 20 17:55:22.680822 IP 10.0.0.2.40724 > 10.0.0.1.5050: UDP, length 20 17:55:22.708273 IP 10.0.0.1.5050 > 10.0.0.2.40724: UDP, length 20 ^C 15 packets captured 17 packets received by filter 0 packets dropped by kernel admin@osdx$
Note
Note that only UDP traffic is captured because the traffic selector is configured to filter UDP packets exclusively.
Test duplicate local traffic to a remote IP with VRF
Description
This scenario configures remote port mirroring on DUT0 (‘eth0’ interface). Local-in and local-out traffic policies duplicate traffic to a remote IP address. The interface is configured within a VRF, which must be specified as the output VRF. A traffic selector is configured to filter and duplicate only UDP traffic.
Scenario
Step 1: Set the following configuration in DUT0 :
set interfaces ethernet eth0 address 10.0.0.1/24 set interfaces ethernet eth0 traffic policy local-in DUP_POLICY set interfaces ethernet eth0 traffic policy local-out DUP_POLICY set interfaces ethernet eth2 address 20.0.0.1/24 set interfaces ethernet eth2 vrf VRF1 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0' set system vrf VRF1 set traffic policy DUP_POLICY rule 1 action accept set traffic policy DUP_POLICY rule 1 duplicate remote 20.0.0.2 local-vrf VRF1 set traffic policy DUP_POLICY rule 1 selector UDP_SEL set traffic selector UDP_SEL rule 1 protocol udp
Step 2: Set the following configuration in DUT1 :
set interfaces ethernet eth0 address 10.0.0.2/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0'
Step 3: Set the following configuration in DUT2 :
set interfaces ethernet eth2 address 20.0.0.2/24 set system login user admin authentication encrypted-password '$6$GSjsCj8gHLv$/VcqU6FLi6CT2Oxn0MJQ2C2tqnRDrYKNF8HIYWJp68nvXvPdFccDsT04.WtigUONbKYrgKg8d6rEs8PjljMkH0'
Step 4: Ping IP address 10.0.0.1 from DUT1:
admin@DUT1$ ping 10.0.0.1 count 1 size 56 timeout 1Show output
PING 10.0.0.1 (10.0.0.1) 56(84) bytes of data. 64 bytes from 10.0.0.1: icmp_seq=1 ttl=64 time=0.402 ms --- 10.0.0.1 ping statistics --- 1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.402/0.402/0.402/0.000 ms
Step 5: Ping IP address 20.0.0.1 from DUT2:
admin@DUT2$ ping 20.0.0.1 count 1 size 56 timeout 1Show output
PING 20.0.0.1 (20.0.0.1) 56(84) bytes of data. 64 bytes from 20.0.0.1: icmp_seq=1 ttl=64 time=0.252 ms --- 20.0.0.1 ping statistics --- 1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.252/0.252/0.252/0.000 ms
Note
Start packet capture on DUT2 eth2 to monitor duplicated traffic
Step 6: Initiate a tcp connection from DUT1 to DUT0 and try to send some messages between both endpoints
admin@DUT0$ monitor test connection server 5050 tcp admin@DUT1$ monitor test connection client 10.0.0.1 5050 tcp
Step 7: Initiate a udp connection from DUT1 to DUT0 and try to send some messages between both endpoints
admin@DUT0$ monitor test connection server 5050 udp admin@DUT1$ monitor test connection client 10.0.0.1 5050 udp
Note
Stop packet capture. Expected output:
Show output
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode listening on eth2, link-type EN10MB (Ethernet), snapshot length 262144 bytes 17:55:31.359240 IP6 :: > ff02::16: HBH ICMP6, multicast listener report v2, 4 group record(s), length 88 17:55:31.519325 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 4 group record(s), length 88 17:55:31.531228 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 1 group record(s), length 28 17:55:31.595239 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 1 group record(s), length 28 17:55:32.511234 IP6 fe80::dcad:beff:feef:6c22 > ff02::16: HBH ICMP6, multicast listener report v2, 4 group record(s), length 88 17:55:35.290216 IP 10.0.0.2.39288 > 10.0.0.1.5050: UDP, length 20 17:55:35.346723 IP 10.0.0.1.5050 > 10.0.0.2.39288: UDP, length 20 17:55:35.384598 IP 10.0.0.2.39288 > 10.0.0.1.5050: UDP, length 20 17:55:35.423432 IP 10.0.0.1.5050 > 10.0.0.2.39288: UDP, length 20 17:55:35.448251 IP 10.0.0.2.39288 > 10.0.0.1.5050: UDP, length 20 17:55:35.485803 IP 10.0.0.1.5050 > 10.0.0.2.39288: UDP, length 20 17:55:35.521708 IP 10.0.0.2.39288 > 10.0.0.1.5050: UDP, length 20 17:55:35.548180 IP 10.0.0.1.5050 > 10.0.0.2.39288: UDP, length 20 17:55:35.586854 IP 10.0.0.2.39288 > 10.0.0.1.5050: UDP, length 20 17:55:35.620330 IP 10.0.0.1.5050 > 10.0.0.2.39288: UDP, length 20 ^C 15 packets captured 15 packets received by filter 0 packets dropped by kernel admin@osdx$
Note
Note that only UDP traffic is captured because the traffic selector is configured to filter UDP packets exclusively.