10 GE Paketbeschleuniger
Übung: einen 10 GE Link zwischen 2 Switchen mittels zweier 1 GE Ports auslasten
Wenn man der blinkenden Link-Leuchte am Switch nicht traut, die behauptet einen funktionsfähigen 10 GE-Link anzuzeigen, dann kann man mittels eines Paketbeschleunigers mal testen, ob da wirklich 10GE durch gehen.
Der Trick: 20 VLANs einrichten, per Patchkabel jeweils abwechselend auf einem Switch bridgen und mit den 2 Rechnern in unterschiedlichen VLANs Traffic erzeugen
Notwenige Hardware
- 2x HP 3800 oder 5400 mit SFP+ und min. 20 Kupferports
- 2x 10 GE SFP+ GBICs
- 2 Rechner mit Linux, Gbit-fähig
- Glas-Patchkabel und Adapter für einen LC-LC-Direktlink
- 20 kurze RJ45-Patchkabel
- evtl. serielles Kabel + Adapter zum Switch konfigurieren
Aufbau
- 2 HP-Switche mit Strom und 10 GE-GBICs bestücken
- GBICs mit Patchkabel verbinden
- Kupferpatches (Ports auf einem Switch kurzschließen)
- Switch A
- Port 1-2
- Port 3-4
- usw.
- Port 19-20
- Switch B
- Port 2-3
- Port 4-5
- usw.
- Port 18-19
- Rechner an Switch B, Port 20 und 21 (oder höher) anschließen
Bilder
Switch-Config
- auf beiden Switchen
- VLANs 2-20 anlegen
- Port 1 → DEFAULT_VLAN untagged
- Port 2 → VLAN 2 untagged
- usw.
- Port 20 → VLAN 20 untagged
- 10 GE Port → DEFAULT_VLAN untagged, Alle anderen VLANS tagged
- auf Switch B für die beiden Rechner
- Port 20 → VLAN 20 untagged
- Port 21 → DEFAULT_VLAN untagged
- Mgmt-IP: 10.0.0.3 (Netzmaske: 255.255.255.0) im DEFAULT_VLAN
Traffic erzeugen
1. beiden Rechnern je eine IP anlegen
Rechner 1
ip link set dev eth0 up ip addr add 10.0.0.1/24 dev eth0
Rechner 2
ip link set dev eth0 up ip addr add 10.0.0.2/24 dev eth0
2. auf Rechner 1 einen Server starten
Daten empfangen
nc -l -p 1234 > /dev/null
3. auf Rechner 2 einen Client starten und Daten reinkippen
Daten senden
cat /dev/zero | nc 10.0.0.1 1234
4. Portcounter beim Überlaufen zugucken ;)
Portauslastung anzeigen
- Switch A oder B eine IP im DEFAULT_VLAN geben
- 10.0.0.3/24
- auf Rechner im DEFAULT_VLAN
- Script (siehe unten) aufrufen (benötigt SNMP-Tools, unter Debian „apt-get install snmp“)
Portauslastung anzeigen
# Usage: -h <ip vom switch> -s <snmp communitystring> -i <interface-nr des 10GE Ports> ./snmp_bandwidth.sh -h 10.0.0.3 -s public -i 25
erwartete Ausgabe
Ausgabe der Portauslastung
Inbound: 10501 Mbps, Outbound: 10498 Mbps, Speed: 10000 Mbps Inbound: 10452 Mbps, Outbound: 10450 Mbps, Speed: 10000 Mbps
Bashscript
snmp_bandwidth.sh
init () { INTNUMBER=$interface OUT=$(snmpget -v2c -c $community_string $hostname ifHCOutOctets.$INTNUMBER | awk '{print $4}') IN=$(snmpget -v2c -c $community_string $hostname ifHCInOctets.$INTNUMBER | awk '{print $4}') #SPEED=$(snmpget -v2c -c $community_string $hostname ifSpeed.$INTNUMBER | awk '{print $4}') SPEED=10000000000 TIME=1 if [ -z "$OUT" ] || [ -z "$IN" ]; then msg="Unable to retrieve SNMP info." state=CRITICAL echo $state $msg exit 2 fi } check () { #wait $TIME before running the same check, this way we can confirm how much the data has changed in two periods. sleep $TIME OUT2=$(snmpget -v2c -c $community_string $hostname ifHCOutOctets.$INTNUMBER | awk '{print $4}') IN2=$(snmpget -v2c -c $community_string $hostname ifHCInOctets.$INTNUMBER | awk '{print $4}') DELTAOUT=$(( $OUT2 - $OUT)) DELTAIN=$(( $IN2 - $IN)) #Value is in octets so will need to be divided by 8 to get bytes, this is then divided by 1024 to give kilobytes. INPUTBW=$(((($DELTAIN)/$TIME)*8)) OUTPUTBW=$(((($DELTAOUT)/$TIME)*8)) #For percentage usage we do 100/(total possible bandwidth – current bandwidth). percentage_use=$(echo "scale=9; $INPUTBW/$SPEED" | bc) PRCNTIN=$(echo "scale=0; 100*$percentage_use" | bc) percentage_use=$(echo "scale=9; $OUTPUTBW/$SPEED" | bc) PRCNTOUT=$(echo "scale=0; 100*$percentage_use" | bc) echo "Inbound: " $((INPUTBW/1000000)) "Mbps ($PRCNTIN% Used), Outbound: " $((OUTPUTBW/1000000)) "Mbps ($PRCNTOUT% Used), Speed: " $(($SPEED/1000000)) "Mbps" IN=$IN2 OUT=$OUT2 } while getopts ":i:s:h:" option do case $option in i)interface=$OPTARG ;; s)community_string=$OPTARG ;; h)hostname=$OPTARG ;; *) echo "Syntax is $usage -h <hostname> -s <snmpstring> -i <interface-nr>" exit 1;; esac done if [ -z "$hostname" ]; then echo "-h) IP address required." exit 1 elif [ -z "$community_string" ]; then echo "-s) snmp string needs to be specified." exit 1 elif [ -z "$interface" ]; then echo "-i) interface number required." exit 1 else init while true do check done fi