Date created: Friday, August 18, 2023 9:33:53 AM. Last modified: Tuesday, February 13, 2024 10:45:38 AM
ethxmit
Example: https://www.youtube.com/watch?v=3q7X1kGdrtU
ethxmit is a tool to generate IP/TCP/UDP/ICMP/MPLS frames on EOS.
r2#bash Arista Networks EOS shell [r2 ~]$ ethxmit Usage: ethxmit [ OPTIONS ] interface ethxmit: error: expected output interface [r2 ~]$ ethxmit --help Usage: ethxmit [ OPTIONS ] interface Options: -h, --help show this help message and exit -s SIZE, --size=SIZE packet size, including CRC (default: minimum possible size, typically 64) -S SMAC, --smac=SMAC source MAC address (default: use interface's MAC address) --incSmac=INCSMAC increment source mac repeating after N iterations (max 65535) -D DMAC, --dmac=DMAC destination MAC address (default: ff:ff:ff:ff:ff:ff) --incDmac=INCDMAC increment dest mac repeating after N iterations (max 65535) -e ETHERTYPE, --ethertype=ETHERTYPE ethertype (default: 0x1234) -V IP_VERSION, --ip-version=IP_VERSION IP version either 4 or 6 (default: 4) -p, --progress display progress indication to stdout --vlan=VLAN vlan id (default: no tag, or 0 if --vpri is set) --vpri=VPRI vlan priority (default: no tag, or 0 if --vlan is set) --dei dei (default: no tag, or 0 if --vpri is set) --vlan-tpid=VLAN_TPID vlan TPID (default: 0x8100) --inner-vlan=INNER_VLAN inner vlan id (default: no tag, or 0 if --inner-vpri is set) --inner-vpri=INNER_VPRI inner vlan priority (default: no tag, or 0 if --inner- vlan is set) --inner-dei inner vlan dei ( default: no tag, or 0 if --inner-vpri or --inner-vlan is set) --inner-vlan-tpid=INNER_VLAN_TPID inner vlan TPID (default: 0x8100) --ip-src=ADDR source IP address --ip-dst=ADDR destination IP address --ip-protocol=PROTO IP protocol number or name (default: 63) --ip-src-inc=IP_SRC_INC increment source IP address, repeating after N iterations --ip-dst-inc=IP_DST_INC increment destination IP address, repeating after N iterations --ttl=TTL IP TTL (Time To Live) value (default: 64) --tos=TOS IP TOS (Type Of Service) value (default: 0) --flow-label=FLOW_LABEL IPv6 Flow Label value (default: 0) --dont-fragment Set IP Don't Fragment flag as 1 --more-fragments Set IP More Fragments flag as 1 --frag-offset=FRAG_OFFSET Fragment offset in units of 64-bits (e.g. 1 = 64 bits) --ip-id=IP_ID IP header id --router-alert add a Router Alert IP option --cksum=CKSUM IP Checksum --ipver=IPVER IPv4 version to generate a version error --iphlen=IPHLEN IPv4 Header Length --udp-sport=PORT UDP source port number --udp-dport=PORT UDP destination port number --icmp-type=ICMP_TYPE ICMP type --icmp-code=ICMP_CODE ICMP code --inner-udp-sport=PORT inner source UDP port for a tunneled IP/UDP packet --inner-udp-dport=PORT inner dest UDP port for a tunneled IP/UDP packet --inner-tcp-sport=PORT inner source TCP port for a tunneled IP/TCP packet --inner-tcp-dport=PORT inner dest TCP port for a tunneled IP/TCP packet --inner-tcp-flags=INNER_TCP_FLAGS Set TCP control flags: U,A,P,R,S,F --inner-ip-protocol=PROTO IP protocol number or name (default: 63) for a tunneled IP packet --inner-ttl=INNER_TTL IP TTL (Time To Live) value (default: 64) for a tunneled IP packet --inner-tos=INNER_TOS IP TOS (Type Of Service) value (default: 0) for a tunneled IP packet --inner-flow-label=INNER_FLOW_LABEL IPv6 Flow Label value (default: 0) for a tunneled IP packet --inner-ip-src=ADDR inner source IP address for a tunneled IP packet --inner-ip-dst=ADDR inner destination IP address for a tunneled IP packet --inner-smac=INNER_SMAC source MAC address for inner header of a tunneled packet (default: 00:00:aa:aa:aa:aa) --inner-dmac=INNER_DMAC destination MAC address for inner header of a tunneled packet (default ff:ff:ff:ff:ff:ff) --inner-ethertype=INNER_ETHERTYPE ethertype for inner header of a tunneled packet (default: 0x0800 for IP) --inner-ip-version=INNER_IP_VERSION IP version either 4 or 6 (default: 4) of a tunneled IP packet --inner-dont-fragment Set IP Don't Fragment flag as 1 for a tunneled IP packet --inner-more-fragments Set IP More Fragments flag as 1 for a tunneled IP packet --inner-frag-offset=INNER_FRAG_OFFSET Fragment offset in units of 64-bits (e.g. 1 = 64 bits) for a tunneled IP packet --inner-ip-id=INNER_IP_ID IP header id for a tunneled IP packet --inner-arp=INNER_ARP ARP: "request", "reply" --inner-ndp=INNER_NDP --inner-ndp <"nbr-solicit", "nbr-advt", "rtr-solicit"> --vxlan-vni=VXLAN_VNI vni for Vxlan packet (adds vxlan header). Also: Sets IP_PROTO to udp and dest port to vxlan port, unless overridden --vxlan-flags=VXLAN_FLAGS Sets VXLAN flags (first 8 bits of VXLAN header) --payload-vlan=PAYLOAD_VLAN Payload vlan id (default: no tag, or 0 if --payload- vpri is set) --payload-vpri=PAYLOAD_VPRI Payload vlan priority (default: no tag, or 0 if --payload-vlan is set) --payload-dei payload vlan dei ( default: no tag, or 0 if --payload- vlan or --payload-vpri is set) --payload-vlan-tpid=PAYLOAD_VLAN_TPID Payload vlan TPID (default: 0x8100) --payload-inner-vlan=PAYLOAD_INNER_VLAN Payload inner vlan id (default: no tag, or 0 if --payload-inner-vpri is set) --payload-inner-dei payload inner vlan dei ( default: no tag, or 0 if --payload-inner-vpri or --payload-inner-vlan is set) --payload-inner-vpri=PAYLOAD_INNER_VPRI Payload inner vlan priority (default: no tag, or 0 if --payload-inner-vlan is set) --payload-inner-vlan-tpid=PAYLOAD_INNER_VLAN_TPID Payload inner vlan TPID (default: 0x8100) --mpls-label=LABEL A comma separated list of MPLS (Multiprotocol Label Switching) labels to be added to the packet. Specified from top to bottem --mpls-ttl=MPLS_TTL comma separated MPLS TTL (Time To Live) value (default: 64) --mpls-exp=MPLS_EXP comma separted MPLS EXP (Experimental ) value (default: 0) --gre enable Generic Routing Encapsulation (GRE) --gre-over-mpls enable Generic Routing Encapsulation (GRE) over MPLS --gtpv1 enable GTPv1 encapsulation --gtpv1-msg-type=GTPV1_MSG_TYPE GTPv1 message type --gtpv1-teid=GTPV1_TEID GTPv1 tunnel endpoint identifier --eth-over-gre enable Ethernet over Generic Routing Encapsulation (GRE) --udp-over-mpls enable UDP over MPLS --eth-over-mpls enable Ethernet over MPLS --mpls-pw-cw-type=MPLS_PW_CW_TYPE set the MPLS Pseudowire Control Word Type (default 0) --mpls-pw-cw-flags=MPLS_PW_CW_FLAGS set the MPLS Pseudowire Control Word Flags (default 0) --mpls-pw-cw-frg=MPLS_PW_CW_FRG set the MPLS Pseudowire Control Word Fragment (default 0) --mpls-pw-cw-seqno=MPLS_PW_CW_SEQNO set the MPLS Pseudowire Control Word Sequence Number (default 0) --mpls-pw-cw-raw=MPLS_PW_CW_RAW set the raw MPLS Pseudowire Control Word (4-byte hex string) --gre-protocol=PROTO set the protocol type of the GRE payload (default: 0x0800 (IP)) --gre-version=VER set the GRE version number (default 0) --gre-checksum=VALUE enable Checksum Present bit in GRE header and insert checksum with VALUE, not enabled by default --gre-key=VALUE enable Key Present bit in GRE header and insert key with VALUE, not enabled by default --gre-sequence=VALUE enable Sequence Number Present bit in GRE header and insert sequence number with VALUE, not enabled by default --data-type=TYPE one of: constant, incrementing, random, raw (default: incrementing) --data-value=VALUE payload value if data-type is 'constant' or 'raw' constant: single byte repeated to fill payload SIZE raw: hex string for payload, zero padded if short (default: 0) --random-seed=SEED seed for random number generator --vnTagSVif=VNTAGSVIF source Vif, the vif_id of the port that add the vntag --vnTagDVif=VNTAGDVIF destination Vif, identifies the destination port --br=BR IEEE 802.1BR E-tag --l2-ts-ver=L2_TS_VER Arista L2 timestamp tag version --l2-ts-sec=L2_TS_SEC Arista L2 timestamp tag seconds --l2-ts-nsec=L2_TS_NSEC Arista L2 timestamp tag nanoseconds --dzgre enable DzGRE header --dzgre-version=VER set the DzGRE version number (default 0) --dzgre-entropy=VALUE Arista DzGRE entropy --dzgre-switch-id=DZGRE_SWITCH_ID Arista DzGRE switch Id --dzgre-port-id=DZGRE_PORT_ID Arista DzGRE port Id --dzgre-policy-id=DZGRE_POLICY_ID Arista DzGRE policy Id -n NUM, --num=NUM total number of packets to send (default: 1) --seq replace last four bytes of user payload with incrementing sequence value -b BURST, --burst=BURST number of packets in each burst (default: 1) --sleep=SLEEP how long to sleep (in seconds) after each burst (default: 0.0) -c, --continuous run continuously -B SNDBUF, --sndbuf=SNDBUF socket send-buffer size to use --arp=ARP ARP: "request", "reply" --rarp=RARP RARP: "request", "reply" --arp-sha=ARPSHA Sender Hardware Address in ARP/RARP message (default: smac) --ndp=NDP --ndp <"nbr-solicit", "nbr-advt", "rtr-solicit"> --isl-f1=F1 f1 field in ISL header --isl-f2=F2 f2 field in ISL header --isl-sglort=SGLORT sglort field in ISL header --isl-dglort=DGLORT dglort field in ISL header --txraw-fap=TXRAWFAP src FAP in txraw header --svtag=SVTAG 4 byte svtag --ptch-sysSrcPort=SYSSRCPORT src Port to inject packet from --itmh-sysDestPort=SYSDESTPORT sysDestPort in ITMH header --raw=RAW Hexidecimal byte stream (e.g. 0xaaaa010234....) of a pre-formed packet to use. All other packet building options are ignored. --stdout write packet to stdout --hexDump print the hex value of the packet --tcp-flags=TCP_FLAGS Set TCP control flags: U,A,P,R,S,F --tcp-sport=TCP_SPORT TCP source port number --tcp-dport=TCP_DPORT TCP destination port number --tcp-mss=TCP_MSS TCP maximum segment size --esmc-ssm=ESMC_SSM ESMC SSM value (0-15) --esmc-type=ESMC_TYPE ESMC type: informational (I) or event (E) (default: I) --src-port-inc=SRC_PORT_INC increment source port, repeating after N iterations (max 65535) --dst-port-inc=DST_PORT_INC increment destination port, repeating after N iterations (max 65535)
Previous page: Traffic Policy Match Statements
Next page: tcpdump