knb:rpb4

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen Revision Vorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
knb:rpb4 [2022/02/01 16:21] – [Offloader auf Basis eines Raspberry PI 4B] goligoknb:rpb4 [2023/11/08 17:36] (aktuell) – [Offloader auf Basis eines Raspberry PI 4B] goligo
Zeile 9: Zeile 9:
 Offloader auf Basis eines Raspberry PI 4B - eine Kurzanleitung von **[[https://chat.ffmuc.net/freifunk/messages/@goligo|goligo]]**. Offloader auf Basis eines Raspberry PI 4B - eine Kurzanleitung von **[[https://chat.ffmuc.net/freifunk/messages/@goligo|goligo]]**.
  
-Dieser Anleitung beschreibt das Aufsetzen eines Offloaders auf dem Raspberry mit der vorhandenen Freifunk-Firmware. Es kann entweder ein zusätzlicher USB-LAN-Adapter angeschlossen werdenoder wenn man einen VLAN-fähigen Switch hat, geht es auch nur mit dem einen vorhandenen Netzwerkport.+Dieser Anleitung beschreibt das grundsätzliche Aufsetzen eines Offloaders auf dem Raspberry PI 4B mit der vorhandenen Freifunk München-Firmware. Es kann entweder ein zusätzlicher USB-LAN-Adapter angeschlossen werden oderwenn man einen VLAN-fähigen Switch hat, geht es auch nur mit dem einen vorhandenen Netzwerkport.
  
-Der Raspberry PI 4 ist schnell genug um eine 250 MBit/s Leitung voll auszulasten, unabhängig davon ob man mit zusätzlichem Adapter oder VLAN arbeitet.+Der Raspberry PI 4 ist schnell genugum eine 250 MBit/s Leitung voll auszulasten, unabhängig davonob man mit einem zusätzlichen Adapter oder einem VLAN arbeitet. 
 + 
 +<WRAP center round important 80%> 
 +**Wichtiger Hinweis**((Stand: Nov. 2023)): \\ \\ 
 +Upstream Gluon supportet den Pi4 nur experimentell, weil die WiFi-Hardware im Raspberry 4 nicht tauglich ist für den Betrieb als WLAN Access Point. Hintergrund ist, dass die PIs alle FullMAC/HardMAC Radios haben, die per USB angebunden sind. Bei diesen fehlen wichtige Modes z.B. fürs meshen.  
 +Das bedeutet als Offloader kann man ihn nur sinnvoll einsetzen, wenn man das Mesh-Netz, bzw. das Client-Netz über den LAN-Port oder einen externen USB-LAN-Adapter ausleitet und auf die Verwendung als AP oder WLAN-Mesh-Node verzichtet. 
 +</WRAP>
  
 ==== Hardware ==== ==== Hardware ====
  
-Man benötigt natürlich einen Raspberry PI 4 am besten in einem ordentlichem Gehäuse, ausserdem eine MicroSD-Karte mit wenigstens 1GB Speicher:+Man benötigt natürlich einen Raspberry PI 4am besten in einem ordentlichem Gehäuse, ausserdem eine MicroSD-Karte mit wenigstens 1GB Speicher:
  
 {{:knb:raspberry_pi_4.jpg?400|}} {{:knb:raspberry_pi_4.jpg?400|}}
  
-Je nach Setup zusätzlich einen USB 3.0 LAN-Adapter, der von Gluon/OpenWrt unterstützt wird. Da es sich um einen Linux-Kernel handelt, gibt es Treiber für viele Hersteller, man sollte sich aber unbedingt vor dem Kauf schlau machen. Eine Liste der Chipsets für die es Treiber gibt, findet man hier: [[https://openwrt.org/packages/table/start?dataflt%5BName_pkg-dependencies*%7E%5D=kmod-usb-net|OpenWrt Netzwerk Treiber]]. Das Firmware-Image für den Raspberry PI 4 enthält bereits die meisten üblichen Treiber.+Je nach Setup wird zusätzlich ein USB 3.0 LAN-Adapter benötigt, der von Gluon/OpenWrt unterstützt wird. Da es sich um einen Linux-Kernel handelt, gibt es Treiber für viele Hersteller. Man sollte sich aber unbedingt vor dem Kauf darüber informieren. Eine Liste der Chipsetsfür die es Treiber gibt, findet man hier: [[https://openwrt.org/packages/table/start?dataflt%5BName_pkg-dependencies*%7E%5D=kmod-usb-net|OpenWrt Netzwerk Treiber]]. Das Firmware-Image für den Raspberry PI 4 enthält bereits die meisten üblichen Treiber.
  
 {{:knb:usb_lan_adapter.jpg?400|}} {{:knb:usb_lan_adapter.jpg?400|}}
Zeile 29: Zeile 35:
 [[https://firmware.ffmuc.net/?q=Raspberry%C2%A0Pi%C2%A0Foundation%E2%81%A3%20PI4%E2%81%A3|Raspberry PI 4 Firmware Download]] [[https://firmware.ffmuc.net/?q=Raspberry%C2%A0Pi%C2%A0Foundation%E2%81%A3%20PI4%E2%81%A3|Raspberry PI 4 Firmware Download]]
  
-Die Firmware auf die SD-Karte zu flashen geht unter Linux oder Mac am einfachsten im Terminal mit dd (auf dem Mac vorher unmounten und Festplatten Vollzugriff für das Terminal erlauben):+Bevor wir das gerade heruntergeladenen Firmware-Image auf die SD-KArte schreiben können, entpacken wir das **.gz** file noch.
  
-<code> +   $ gunzip gluon-ffmuc-<aktuelle version>-raspberry-pi-4-model-b.img.gz
-sudo dd if=gluon-ffmuc-v2021.11.1-next1-raspberry-pi-4-model-b.img of=/dev/rdisk12 bs=65536 +
-</code>+
  
-Unter Windows braucht man ein Programm dazu wie zum Beispiel den [[https://sourceforge.net/projects/win32diskimager/|Win32DiskImager]].+Die Firmware auf die SD-Karte zu flashen geht unter Linux oder MacOS am einfachsten im Terminal mit dem "dd"-Befehl (auf dem Mac vorher eine evtl. bereits vorhandene Partition unmounten und Festplatten den Vollzugriff für das Terminal erlauben): 
 + 
 +   $ sudo dd if=gluon-ffmuc-<aktuelle version>-raspberry-pi-4-model-b.img of=/dev/<sdcard device> bs=65536 
 + 
 +Unter Windows braucht man dazu ein Programm wie zum Beispiel den [[https://sourceforge.net/projects/win32diskimager/|Win32DiskImager]].
  
 ==== Setup ==== ==== Setup ====
  
-Jetzt kann man die SD-Karte in den Raspberry Pi stecken, den Computer per Netzwerkkabel anschliessen, DHCP einschalten und den Raspberry Pi starten. Nach kurzer Zeit ist die Setup-Wizard unter  +Jetzt kann man die SD-Karte in den Raspberry Pi stecken, den Computer direkt per Netzwerkkabel anschließen, DHCP aktivieren und den Raspberry Pi starten. Nach kurzer Zeit ist die Setup-Wizard im Browser unter http://192.168.1.1 zu erreichen und der neue Raspberry-Knoten kann wie gewohnt eingerichtet werden
-http://192.168.1.1 zu erreichen und der Knoten kann wie gewohnt eingerichtet werden.+ 
 +**Wichtig:** Zuerst auf "Erweiterte Einstellungen" gehen und dort unter "Remotezugriff" den SSH-Key hinterlegen, so dass man später auf den Knoten zugreifen kann. Danach erst auf "Wizard" gehen, um den Knotennamen und die restlichen Einstellungen vorzunehmen.
  
-**Wichtig:** Zuerst auf "Erweiterte Einstellungen" gehen und dort unter "Remotezugriff" den SSH-Key hinterlegen, so dass man später auf den Offloader zugreifen kann. Danach erst auf "Wizard" um den Namen des Knotens und die anderen Einstellungen vorzunehmen.+Nach der Einrichtung kann der Knoten nun vom Einrichtungscomputer abgesteckt und ans lokale Netzwerk angeschlossen werdenEr ist in der Regel nach kurzer Zeit unter dem Namen des Knotens erreichbar und man kann sich per SSH darauf einloggen.
  
-Nach der Einrichtung kann der Knoten nun ans lokale Netzwerk angeschlossen werden. Er ist in der Regel nach kurzer Zeit unter dem Namen des Knotens erreichbar und man kann per SSH darauf einloggen:+Hier folgt ein Beispiel mit dem Knotennamen "raspi4" und dem Knoten angeschlossen an einer AVM Fritz!Box:
  
 <code> <code>
Zeile 70: Zeile 79:
 ==== USB 3.0 LAN Adapter ==== ==== USB 3.0 LAN Adapter ====
  
-Wenn man einen USB-LAN-Adapter verwenden möchte, so kann man diesen jetzt anschliessen und sich per SSH einloggen um diesen einzurichten. Als erstes schaut man am besten mit "lsusb" ob der Adapter erkannt wurde und als was, dann prüft man ob auch das zugehörige Ethernet-Interface schon vorhanden istoder ob man noch Treiber installieren muss.+Wenn man einen USB-LAN-Adapter verwenden möchte, so kann man diesen jetzt anschließen und sich per SSH einloggenum diesen einzurichten. Als erstes schaut man am besten mit "lsusb"ob der Adapter erkannt wurde und als was. Dann prüft man ob auch das zugehörige Ethernet-Interface vorhanden ist oder ob man noch zusätzliche Treiber installieren muss.
  
 <code> <code>
Zeile 88: Zeile 97:
 </code> </code>
  
-Um Gluon jetzt beizubringen, dass ein zusätzliches Netzwerk-Interface vorhanden ist, muss man die Datei "/lib/gluon/core/sysconfig/lan_ifname" anlegen mit dem Namens des Interfaces als Inhalt. Danach ruft man "gluon-reconfigure" um die Konfiguration zu aktualisieren. Danach sollte "eth1" mit ins Client-Netzwerk aufgenommen sein und nach einem Neustart des Knotens sollte ein angeschlossener Computer  Freifunk-Netzwerk haben auf dem Anschluss.+Um Gluon jetzt beizubringen, dass ein zusätzliches Netzwerk-Interface vorhanden ist, muss man per uci einen zusätzlichen Interface-Eintrag dafür anlegen. Danach ruft man "gluon-reconfigure" auf, um die Konfiguration zu aktualisieren. Dann sollte "eth1" mit ins Client-Netzwerk aufgenommen sein und nach einem Neustart des Knotens sollte ein angeschlossener Computer Freifunk-Netzwerk haben auf dem Anschluss.
  
 <code> <code>
-root@raspi4:~# echo eth1 > /lib/gluon/core/sysconfig/lan_ifname+root@raspi4:~# uci set gluon.iface_lan=interface 
 +root@raspi4:~# uci set gluon.iface_lan.name='eth1
 +root@raspi4:~# uci add_list gluon.iface_lan.role='client' 
 + 
 +root@raspi4:~# uci commit gluon
  
 root@raspi4:~# gluon-reconfigure  root@raspi4:~# gluon-reconfigure 
Zeile 103: Zeile 116:
 network.client.ifname='local-port' 'bat0' 'eth1' network.client.ifname='local-port' 'bat0' 'eth1'
  
-root@raspi4:~# reboot+root@raspi4:~# service network restart
 </code> </code>
  
 ==== VLAN Betrieb ==== ==== VLAN Betrieb ====
  
-Wenn man einen VLAN-fähigen Switch hat, kommt man auch ohne zusätzlichen Netzwerk-Adapter aus. Man muss in diesem Fall das WAN- und LAN-Interface entsprechend für seine VLAN-Konfiguration setzen, hier in diesem Beispiel ist das WAN auf VLAN-ID 10 und das Freifunk-Netzwerk auf VLAN-ID 20.+Wenn man einen VLAN-fähigen Switch hat, kommt man auch ohne zusätzlichen Netzwerk-Adapter aus. Man muss in diesem Fall das WAN- und LAN-Interface entsprechend der VLAN-Konfiguration setzen
 + 
 +Hier in diesem Beispiel ist das WAN auf der VLAN-ID 10 und das Freifunk-Netzwerk auf der VLAN-ID 20.
  
 <code> <code>
-root@raspi4:~# echo eth0.10 > /lib/gluon/core/sysconfig/wan_ifname +root@raspi4:~# uci del_list gluon.iface_single.role='uplink' 
 +root@raspi4:~# uci add_list gluon.iface_single.role='none' 
 +root@raspi4:~# uci set gluon.iface_wan=interface 
 +root@raspi4:~# uci set gluon.iface_wan.name='eth0.10
 +root@raspi4:~# uci add_list gluon.iface_wan.role='uplink' 
 +root@raspi4:~# uci set gluon.iface_lan=interface 
 +root@raspi4:~# uci set gluon.iface_lan.name='eth0.20' 
 +root@raspi4:~# uci add_list gluon.iface_lan.role='client'
  
-root@raspi4:~# echo eth0.20 > /lib/gluon/core/sysconfig/lan_ifname+root@raspi4:~# uci commit gluon
  
 root@raspi4:~# gluon-reconfigure root@raspi4:~# gluon-reconfigure
Zeile 122: Zeile 144:
 Configuring: 999-version Configuring: 999-version
  
-root@raspi4:~# reboot+root@raspi4:~# service network restart
 </code> </code>
  
 ==== Mesh-On-LAN ==== ==== Mesh-On-LAN ====
  
-Wenn man den Offloader für ein Unifi oder Omada Mesh verwendet, ist man jetzt fertig und kann den Offloader anschliessen. Wenn man Mesh-On-LAN verwenden will und andere Freifunk-Knoten per Kabel verbinden, muss man das noch umstellen, indem man das LAN-Interface aus dem Client-Netzwerk entfernt und Mesh-On-LAN aktiviert.+Wenn man den Offloader für ein Unifioder Omada-Mesh verwendet, ist man jetzt fertig und kann den Offloader anschließen. Wenn man Mesh-On-LAN verwenden und andere Freifunk-Knoten per Kabel verbinden will, muss man das noch umstellen, indem man das LAN-Interface aus dem Client-Netzwerk entfernt und Mesh-On-LAN aktiviert.
  
 <code> <code>
-root@raspi4:~# uci set network.mesh_lan.disabled=0+root@raspi4:~# uci del_list gluon.iface_lan.role='client' 
 +root@raspi4:~# uci add_list gluon.iface_lan.role='mesh'
  
-root@raspi4:~# uci del_list network.client.ifname=$(cat /lib/gluon/core/sysconfig/lan_ifname)+root@raspi4:~# uci commit gluon 
 + 
 +root@raspi4:~# gluon-reconfigure 
 +Configuring: 001-upgrade 
 +Configuring: 005-set-domain 
 +..
 +Configuring: 998-commit 
 +Configuring: 999-version
  
-root@raspi4:~# uci commit network+root@raspi4:~# service network restart
 </code> </code>
  • knb/rpb4.1643732506.txt.gz
  • Zuletzt geändert: 2022/02/01 16:21
  • von goligo