flooooo
Goto Top

Fehlersuche im lokalem Netzwerk (RSTP, MRP, Multicast)

Hallo liebe Gemeinde!

Kennt wer ein gutes Tool zur Fehlersuche in einem verzweigten Netz in dem Multicast verwendet wird?
Ich glaube das sich ein System sporadisch von der Multicastdomäne abmeldet/ausgeschlossen wird, möchte dies aber gerne genauer analysieren. Das System ist permanent über ping erreichbar, aber beteiligt sich "spontan" nicht mehr an der Multicastdomäne. Glaube das mir hier Wireshark nicht viel helfen kann...

Zweites Anliegen: wäre sehr Dankbar wenn jemand einen Tipp für gute Literatur zu diesem Thema hat face-smile

Vielen Dank im Voraus && viele grüße aus Bayernface-smile
Flo

Content-ID: 362413

Url: https://administrator.de/contentid/362413

Printed on: September 19, 2024 at 11:09 o'clock

UnbekannterNR1
Solution UnbekannterNR1 Jan 26, 2018 at 07:07:56 (UTC)
Goto Top
Mir hat Multicast Hammer sehr geholfen. Literatur suche ich auch noch, möglichst irgendwas deutlich unter 1000 Seiten.


http://multicast-hammer.software.informer.com/2.1/
Flooooo
Flooooo Jan 26, 2018 at 07:18:12 (UTC)
Goto Top
Vielen Dank, das Tool sieht vielversprechend aus!

Das mit der Literatur ist glaube ich echt ein Problem....
aqui
Solution aqui Jan 26, 2018, updated at Sep 19, 2024 at 07:19:20 (UTC)
Goto Top
Kennt wer ein gutes Tool zur Fehlersuche in einem verzweigten Netz in dem Multicast verwendet wird?
Das Schweizer Armeemesser der Netzwerker: Wireshark!

Speziell zum Testen von Multicasting und Multicast PIM Routing / IGMP Proxy sowie der sehr wichtigen Multicast_zu_Unicast Konvertierung im WLAN bzw. WLAN APs sind 2 freie Tools dafür sehr hilfreich:

back-to-topVideo Streamen via Multicast und GUI


Es geht aber noch viel realitätsnaher und einfacher mit dem allseits bekannten Klassiker VLC wenn man damit Filme oder Audio per Multicast ins Netzwerk streamt:
  • Lade dir einen kleinen, freien Film runter wie z.B. Big Buck Bunny --> https://peach.blender.org bzw. https://download.blender.org/peach/bigbuckbunny_movies/ (Die 320x180.mp4 Version reicht für den Test)
  • Installiere dir den kostenlosen Klassiker VLC. Der rennt auf allen Plattformen, Windows, MacOS, Linux, Raspberry Pi (apt install vlc), Smartphones, Tablets, usw. --> https://www.videolan.org/vlc/index.de.html
  • Starte VLC und streame den o.a. Film als Endlosschleife via Multicast ins Netz. Das geht so:
  • Streaming Assistent im VLC aufrufen Medien --> Stream und mit "+ Hinzufügen" Video Datei wie z.B. oben auswählen.
  • Dann unten den "Stream" Button klicken und im nächsten Fenster "Nächstes"
  • Als Ziel = RTP/MPEG Transportstream auswählen und "Hinzufügen" klicken
  • Als Adresse eine Multicast Adresse z.B. 239.255.1.2 angeben. Port belassen und optional einen Namen angeben z.B. "Kinotest". (⚠️ In deinem Netz sollte diese Multicast Adresse natürlich unbenutzt sein und es sollte KEINE sog. Link Local MC Adresse sein mit festem TTL=1 sein !)
  • Transkodierung deaktivieren (Haken entfernen) und "Nächstes" klicken
  • Wichtig ist hier im Kommando Editor Feld das TTL auf 10 zu setzen. (= damit es dann auch routebar ist !)
  • "Fertig" klicken.
  • Dann in VLC die ">" Play Taste drücken und den Netzwerk Stream starten. Ggf. noch den Film auf Endlosschleife klicken.
vlc1
vlc3
Hier kann man im Wireshark Trace sehen das das TTL entsprechend gesetzt wurde und Multicast damit routebar ist via PIM.
vlc2

back-to-topStream empfangen


So kannst du dann im ganzen Netz mit jedem Endgerät wie PCs, Mac, iPad, Linux, Tablet, iPhone, Smartphone usw. den Film ansehen.
Auch wieder mit VLC als Client indem du "Netzwerkstream öffnen" klickst und als Quelle rtp:@239.255.1.2 eingibst. Ggf. wenn du nicht den Standard Port benutzt, dann den mit einem Doppelpunkt getrennt mit angeben ala rtp:@239.255.1.2:5004
Fertisch !
vlcreceive


back-to-topStreamen via Multicast und Kommandozeile


Multicast Streaming Server mit Linux (Debian, Ubuntu, Raspberry Pi etc.)
Wer einen headless Linux, Raspberry Pi, Linux VM oder ähnlich ohne grafisches GUI betreibt, kann auch ganz einfach über die Kommandozeile per Multicast Filme, wie den von oben, ins Netzwerk streamen. Voraussetzung natürlich VLC ist installiert oder wurde vorher mit sudo apt install vlc (Linux, RasPi) installiert !
Wer zusätzlich noch das Screen Package installiert kann nebenher in einem separaten Terminal im Hintergrund streamen ohne den Stream zu verlieren wenn man sich ausloggt.

Das Kommando sieht dann so aus: (Alles eine Zeile !)
cvlc /home/pi/Videos/BigBuckBunny_320x180.mp4 --sout "#rtp{dst=239.255.1.2,port=5004,ttl=10,mux=ts,sap,name=Bunny}" --no-sout-all --sout-keep --loop 
Achtung: (Das cvlc Kommando kann nicht als Root User ausgeführt werden sondern nur als normaler User. Z.B. "pi" auf dem RasPi!)

back-to-topQoS Priorisierung mit DSCP setzen

Eine interessante Option ist den Multicast Stream mit einer DSCP Priorisierung im Layer 3 Header zu versehen. Hier CS3 (24). Wer einen QoS fähigen Switch besitzt kann den Video Traffic so klassifizieren und über den Switch (und auch Router) priorisiert forwarden. Über die Queue Auslastung des Switches kann man so genau beobachten ob sich der Switch entsprechend den DSCP Settings korrekt verhält. face-wink
cvlc /home/pi/Videos/BigBuckBunny_320x180.mp4 --sout "#rtp{dst=239.255.1.2,port=5004,ttl=10,mux=ts,sap,name=Bunny}" --dscp=96 --no-sout-all --sout-keep --loop 

Nebenbei kann man hier nicht nur Dateien per Multicast streamen sondern natürlich auch Videos direkt von Kameras und Video Capture Karten oder Capture USB Sticks ! Letztere streamen dann alles was einen HDMI Output hat.
Das macht in deinem Umfeld sicher mehr Sinn, das so zu testen, denn jeden kleinen Aussetzer im Netz erkennst du im Client sofort als Ruckler oder Blockartefakte im Film.

back-to-topMulticast Adressierung


Der Multicast Adress Block 239.0.0.0 bis 239.255.255.255 und speziell 239.255.0.0 /16 bzw. 239.192.0.0 /14 ist für die Nutzung in lokalen LANs definiert.
https://www.iana.org/assignments/multicast-addresses/multicast-addresses ...
Und auch RFC 2365.

Wer mehrere Netzwerk Interface Karten am RasPi oder Server hat (wie hier eth1) kann mit dem Parameter --miface=ethX
cvlc /home/pi/Videos/BigBuckBunny_320x180.mp4 --sout "#rtp{dst=239.255.1.2,port=5004,ttl=10,mux=ts,sap,name=Bunny}" --no-sout-all --sout-keep --loop --miface=eth1 
auch zusätzlich noch fest das Interface bestimmen auf dem der Stream gesendet wird wie hier der LAN Port eth1. (Default ist immer eth0). Ein ip a zeigt auf einem Linux Rechner die Netzwerk Interfaces an.

Zusätzlich zu guter Multicast Literatur gibt es auch auf z.B. YouTube eine sehr gute Doku / Schulung zum Thema Multicast:
https://www.youtube.com/watch?v=AvbSMBKBZgY
Alle 6 Teile sind sehenswert für MC Anfänger !
Wer ein gutes Buch zum Thema Multicast sucht wird, wie immer zu Netzwerk Themen, bei Cisco Büchern fündig:
https://www.amazon.de/IP-Multicast-Cisco-Networking-Technology/dp/158714 ...

back-to-top⚠️ Wichtig: IGMP Snooping


Du solltest natürlich tunlichst immer IGMP Snooping auf ALLEN deinen Netzwerk Switches aktiviert haben in einem MC Umfeld !
Andernfalls müsste ein Switch alle diese Multicast Pakete, genau wie Broadcast, an sämtliche Switchports fluten was zu massiven Performance Problemen auf dem Switch, im Netz und Endgeräten führen kann. Ohne aktives IGMP Snooping muss die Switch CPU alle MC Frames kopieren und an aktive Ports forwarden. Weisst du ja aber sicher auch selber.
Wenn man Multicast im WLAN überträgt ist das auch mit Multicast erheblich skalierbarer als zig Einzelstreams. Hier findet man speziell zum Thema Multicast in WLAN Netze noch weitere Detailinfos:
https://www.heise.de/select/ct/archiv/2014/14/seite-76

Ein Beispiel für ein klassisches PIM Routing mit pfSense bzw. OPNsense (PIMD Package) findet man in diesem Thread:
Multicast über VLANs hinweg auf PfSense
Flooooo
Flooooo Jan 30, 2018 at 07:04:07 (UTC)
Goto Top
Danke für die Antwort!
Leider ist streamen nicht möglich, da es sich um keine PC's im eigentlichen Sinne handelt sonder um Industrieanlagen haben die über Multicast kommunizieren.

...Den Tipp mit dem Video nehme ich gerne an! IGMP ist bereits Aktiviert face-wink

Gruß Flo
aqui
aqui Jan 30, 2018 updated at 10:07:26 (UTC)
Goto Top
Trotzdem kann man ja in diese Netze ein paar Testrechner / Laptops hängen, oder ?
Aber war ja nur ein Beispiel wie es geht. MC Hammer geht auch, obwohl du da ja auch wieder 2 Testrechner ins Netz hängen musst.
Na ja...du hast ja nun genug Test Tools um das zum Fliegen zu bringen ! Mit den Show und Debug Kommandos auf den Switches zusammen sollte das ja nicht so schwer sein.
Achte auch darauf das die Switches bzw. Infrastruktur die aktuellsten Firmwares geflasht haben.
Bei Multicast Funktionen pfuschen Hersteller gerne mal. face-wink
Waldwuffel
Waldwuffel Jul 21, 2020 updated at 16:00:55 (UTC)
Goto Top
Im Linux-Bereich finde ich noch empfehlenswert: omping

Die Verwendung ist sehr einfach: auf allen Geräten, die man testen will, laufen lassen:

omping 192.168.0.2 10.0.0.20 -m 239.255.255.250 -p 1900 -t 64

und man kann direkt sehen, wo Multicast eingeht und wo nicht.
Die beteiligten Adressen müssen angegeben werden. Zusätzlich lassen sich eine bestimmte Multicast-Adresse, Port, TTL etc. festlegen.

Eine weitere Möglichkeit ist iperf (das auf einem Linux-System bereits standardmäßig installiert sein könnte). Hier muss man das Programm auf einem Host als Server starten und auf dem zweiten mit entsprechender Konfiguration als Client. Wird eine Multicast-Adresse angegeben, tritt der Server der Gruppe bei und sollte die Pakete vom Client auf diesem Weg erhalten. Auch hier werden Pings durchgeführt, womit sich die Übertragungsgeschwindigkeit usw. ermitteln lässt.

Server:
iperf -s -u -B 239.255.255.250 -p 1900 -i 1

Client:
iperf -c 239.255.255.250 -u -p 1900 -T 4 -t 3 -i 1
aqui
aqui Jul 22, 2020 updated at 08:09:38 (UTC)
Goto Top
Danke für den Tip !
Ob nun UDP Port 1900 eine besonders intelligente Wahl ist da das SSDP ist sei mal dahingestellt.
https://www.iana.org/assignments/service-names-port-numbers/service-name ...
Das könnte man auch weglassen und dann den weniger Konflikt beladenen Standard 5201 nutzen.
Ist aber sicher nur kosmetisch.. face-wink
Waldwuffel
Waldwuffel Jul 22, 2020 at 19:00:55 (UTC)
Goto Top
Ja, die weiteren Optionen kann man natürlich auch weglassen - und wenn es einem erstmal nur darum geht, den MC-Traffic an sich zu untersuchen, sollte man das wohl auch. Beide Tools bieten halt auch die Möglichkeit, den Test genauer einzugrenzen.