Raspberry Pi: Unterschied zwischen den Versionen
Gum (Diskussion | Beiträge) (→Backup erstellen) |
(→Betriebssystem installieren und Basiskonfiguration) |
||
(60 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt) | |||
Zeile 12: | Zeile 12: | ||
#* OneNineDesign Gehäuse (ca. 6 €) |
#* OneNineDesign Gehäuse (ca. 6 €) |
||
# USB-C Steckernetzteil (2 A, ca. 8 €) ([http://www.elektronik-kompendium.de/sites/raspberry-pi/2002021.htm Informationen zu den Netzteilen]) |
# USB-C Steckernetzteil (2 A, ca. 8 €) ([http://www.elektronik-kompendium.de/sites/raspberry-pi/2002021.htm Informationen zu den Netzteilen]) |
||
+ | # Adapter von USB auf Ethernet |
||
# microSD-Karte Class 10 mit mindestens 16 GB Speicher. (ca. 5 €) |
# microSD-Karte Class 10 mit mindestens 16 GB Speicher. (ca. 5 €) |
||
:: Eine Analyse verschiedener Karten gibt es bei [http://elinux.org/RPi_SD_cards elinux.org] und bei [https://www.raspberrypi.org/documentation/installation/sd-cards.md raspberrypi.org]. |
:: Eine Analyse verschiedener Karten gibt es bei [http://elinux.org/RPi_SD_cards elinux.org] und bei [https://www.raspberrypi.org/documentation/installation/sd-cards.md raspberrypi.org]. |
||
Zeile 33: | Zeile 34: | ||
Vor der Bestellung bei Amazon-Händlern sollte darauf geachtet werden, aus welchem Land die Teile verschickt werden. Bei außereuropäischen Händlern sind lange Lieferzeiten einzuplanen. |
Vor der Bestellung bei Amazon-Händlern sollte darauf geachtet werden, aus welchem Land die Teile verschickt werden. Bei außereuropäischen Händlern sind lange Lieferzeiten einzuplanen. |
||
− | |||
− | Conrad hat viele Komponenten in den Ladengeschäften in Dortmund und Essen auch vorrätig. |
||
Die offiziellen Seite von Raspberry Pi Foundation verlinkt [https://www.raspberrypi.org/products/raspberry-pi-4-model-b/ verschiedene Shops]. |
Die offiziellen Seite von Raspberry Pi Foundation verlinkt [https://www.raspberrypi.org/products/raspberry-pi-4-model-b/ verschiedene Shops]. |
||
Zeile 41: | Zeile 40: | ||
== Inbetriebnahme == |
== Inbetriebnahme == |
||
+ | |||
+ | Diese Anleitung geht davon aus, dass Sie entweder mindestens Windows 10 oder ein aktuellen Linux- oder MacOS-Betriebssystem verwenden. |
||
Vor dem ersten Einsatz, muss auf dem Raspberry Pi ein Betriebssystem auf einer SD-Karte installiert werden. |
Vor dem ersten Einsatz, muss auf dem Raspberry Pi ein Betriebssystem auf einer SD-Karte installiert werden. |
||
+ | Führe die folgenden Schritte nacheinander durch. |
||
− | Im MagPi-Magazin werden in einem [https://www.raspberrypi.org/magpi-issues/MagPi60.pdf Troubleshooting Guide] verschiedene Probleme bei der Einrichtung des Pi angesprochen. Schaue dort nach, wenn es Schwierigkeiten gibt. |
||
+ | === Zusammenbau des Raspberry Pi === |
||
− | Führe die folgenden Schritte nacheinander durch. Manchmal gibt es mehrere Möglichkeiten. Entscheide dich dann für eine Option. |
||
+ | Baue das Gehäuse und den Pi zusammen. Lege SD-Karte, SD-Kartenleser, USB-Ethernet-Adapter und Netzteil bereit. |
||
− | === Baue den Raspberry Pi zusammen. === |
||
− | === Betriebssystem |
+ | === Betriebssystem installieren und Basiskonfiguration === |
+ | [[Datei:Pi imager.png|Pi Imager|mini]] |
||
− | ''Option 1: direkter Download'' |
||
+ | Nutze den [https://www.raspberrypi.org/software/ Raspberry Pi Imager] und installiere das Betriebssystem "Raspberry Pi OS". Ein Anleitung findest du [https://www.raspberrypi.com/documentation/computers/getting-started.html#using-raspberry-pi-imager hier]. |
||
− | Ein aktuelles Image von Raspbian oder Raspbian lite gibt es unter [https://www.raspberrypi.org/software/operating-systems/ raspberrypi.org]. |
||
+ | Nimm über den Button "Einstellungen bearbeiten" folgende Einstellungen vor (sollte die Optionen fehlen, kann Sie über Strg-Shift X eingeblendet werden): |
||
− | Lade "Raspberry Pi OS with desktop and recommended software" und entpacke das Archiv. Darin findest du eine img-Datei. |
||
+ | # ''Hostname festlegen'': Dies ist der Name des Pi, über den er im Netz zu finden ist. Wähle einen eindeutigen Namen. Verzichte auf Leerzeichen und Umlaute im Hostnamen und verwende am besten nur Klein- und Großbuchstaben ohne öäüß. Er darf nicht wie dein Laptop heißen. |
||
− | ''Option 2: Download über einen BitTorrent-Client'' |
||
+ | # ''SSH aktivieren'': SSH (Secure SHell) ermöglicht, den sicheren Zugriff auf die Kommandozeile eines Rechners. |
||
+ | # ''Benutzername und Passwort setzen'': WICHTIG! Notiere diese Daten. |
||
+ | # ''WiFi einrichten'' mit den Zugangsdaten des Schul-WLAN |
||
+ | '''Notiere alle vorgenommenen Einstellungen (Hostname, Benutzername, Passwort, Wifi-Zugangsdaten) in einem Dokument und verwahre es sicher.''' |
||
− | Der langsame Download über den Webserver von raspberrypi.org kann mit einem BitTorrent-Client deutlich beschleunigt werden. Unter Windows, Linux und Mac kann hierfür z.B. [https://transmissionbt.com Transmission] genutzt werden. In Transmission kann unter "Editieren", "Eigenschaften", "Netzwerk" mit der Option "Lokale Peersuche verwenden" ([http://bittorrent.org/beps/bep_0014.html Local Service Discovery]) der Download innerhalb eines lokalen Netzes erheblich beschleunigt werden. Hierfür muss ein mDNS/Bonjour-Dienst installiert sein (s.u.). |
||
− | Ein Webdienst, der Bittorrent ermöglicht, ist [https://instant.io/ instant.io]. |
||
− | |||
− | === Installiere Raspbian auf dem Raspberry Pi === |
||
− | |||
− | Kopiere das Image auf eine SD-Karte. |
||
− | |||
− | ''Option 1: Mit dem Raspberry Pi Imager'' |
||
− | |||
− | Nutze den [https://www.raspberrypi.org/software/ Raspberry Pi Imager] |
||
− | |||
− | ''Option 2: Mit dem dd-Befehl unter Linux'' |
||
− | |||
− | Unter Linux oder MacOS kann dies mit dem Befehl 'dd' geschehen. |
||
− | |||
− | [https://gitlab.com/bztsrc/usbimager USBImager] ist ein kleines Programm zum |
||
− | Schreiben von ISO-Images, welches für alle gängigen Betriebssysteme existiert. |
||
− | |||
− | Eine ausführliche Anleitung für beide Varianten befindet sich in der [https://www.rheinwerk-verlag.de/raspberry-pi_3872/ Leseprobe des Raspberry Pi Buches]. |
||
− | |||
− | === Fernzugriff über die Konsole aktivieren === |
||
− | |||
− | * SSH (Secure SHell) ermöglicht, den sicheren Zugriff auf die Kommandozeile eines Rechners. Um diesen Fernzugriff mit ssh zu aktivieren, muss eine Datei mit dem Namen "ssh" im Verzeichnis "boot" abgelegt werden. [https://www.raspberrypi.org/blog/a-security-update-for-raspbian-pixel/] Dazu wird die SD-Karte in einen PC gesteckt, das Laufwerk "boot" ausgewählt und schließlich eine leere Datei "ssh" angelegt. Wichtig: Die Datei "ssh" darf keine Endung ("TXT" o.ä.) haben. |
||
− | * (optional '''erst nach Änderung des Hostnames (siehe unten)''') Damit sich der Pi direkt in ein WLAN-Netz einbucht, kann eine Datei "wpa_supplicant.conf" in dem Verzeichnis "boot" abgelegt werden [https://www.raspberrypi.org/blog/another-update-raspbian/][https://kofler.info/raspberry-pi-zero-w-ausprobiert/]. Ihr Aufbau: |
||
− | |||
− | # Datei wpa_supplicant.conf in der Boot-Partition der SD-Karte |
||
− | network={ |
||
− | ssid="wlan-name" |
||
− | psk="ganz-geheimes-passwort" |
||
− | key_mgmt=WPA-PSK |
||
− | } |
||
==== Funktionsprüfung ==== |
==== Funktionsprüfung ==== |
||
Zeile 97: | Zeile 71: | ||
# Schließe den Pi mit einem Netzteil an eine Steckdose an. |
# Schließe den Pi mit einem Netzteil an eine Steckdose an. |
||
# Verbinde ihn mit einem Ethernetkabel direkt mit dem PC/Laptop. Zwei LED an den Ethernetbuchse des Pi zeigen an, ob eine Verbindung besteht. |
# Verbinde ihn mit einem Ethernetkabel direkt mit dem PC/Laptop. Zwei LED an den Ethernetbuchse des Pi zeigen an, ob eine Verbindung besteht. |
||
− | # Öffne ein Terminal oder die Powershell und versuche ihn mit <tt>ping |
+ | # Öffne ein Terminal oder die Powershell und versuche ihn mit <tt>ping HOSTNAME.local</tt> zu erreichen. <br />'''Hinweis:''' Bei manchen Windowsversionen funktioniert der direkte Zugriff ggf. über den Hostnamen nicht mehr. Durch die Eingabe von <tt>ping -4 HOSTNAME.local </tt> in der Eingabeaufforderung, erhält man die IPv4 Adresse des Raspberry Pi. Mit dieser IP-Adresse ist der Fernzugriff möglich. |
− | # Wenn alles geklappt hat, bekommst du eine Antwort vom Pi. |
+ | # Wenn alles geklappt hat, bekommst du eine Antwort vom Pi. Sollte es nicht sofort klappen, hab etwas Geduld! Der erste Start des neuen Betriebssystems dauert etwas länger. Erst wenn der "ping" funktioniert, kannst du fortfahren. |
− | # Verbindung mit SSH: Öffne die Powershell(Windows) oder ein Terminal (Linux, MacOS) und stelle eine Verbindung mit <tt>ssh |
+ | # Verbindung mit SSH: Öffne die Powershell(Windows) oder ein Terminal (Linux, MacOS) und stelle eine Verbindung mit <tt>ssh BENUTZERNAME@HOSTNAME.local</tt> her. |
+ | ==== Pi herunterfahren und mit dem Internet verbinden ==== |
||
− | Der Standardbenutzername und Passwort des Pi lauten ''pi'' und ''raspberry''. |
||
+ | Der Pi kann nach dem Ändern des Hostname eindeutig identifiziert und daher in einem lokalen LAN oder im WLAN betrieben werden. Fahre dazu den Pi mit <tt>sudo halt</tt> oder <tt>sudo poweroff</tt> herunter. |
||
− | === Hostname ändern === |
||
− | |||
− | Damit sich der Pi namentlich von den anderen Pis unterscheidet, muss der Hostname geändert werden. Verzichte auf Leerzeichen und Umlaute im Hostnamen und verwende am besten nur Klein- und Großbuchstaben ohne öäüß. |
||
− | |||
− | ''Option 1: Über das Netzwerk'' |
||
− | |||
− | Du kannst den Pi in einem Netzwerk oder einer direkten Verbindung unter dem Name "raspberrypi.local" erreichen. |
||
− | |||
− | * Windows: Verbinde dich mit der Powershell per SSH auf raspberrypi.local |
||
− | * Linux: Mit <tt>ssh raspberrypi.local</tt> verbinden |
||
− | |||
− | Nach dem Verbinden kannst du den Hostname mit "sudo raspi-config" ändern. |
||
− | |||
− | ''Option 2: SD-Karte im Linuxrechner'' |
||
− | |||
− | Stecke die SD-Karte in einen Linuxrechner und suche die Datei "/etc/hostname" auf der SD-Karte. Darin kannst du einen neuen Hostnamen eintragen. Danach muss der Pi neu gestartet werden. |
||
− | |||
− | ''Option 3: Verbindung mit der seriellen Schnittstelle (für Experten)'' |
||
− | |||
− | Verbinde einen Rechner über die serielle Schnittstelle mit dem Pi. Hierfür benötigst du einen Adapter, der zwischen dem USB-Port und den GPIO-Pins des Pi angeschlossen wird. Mit dem Programm [http://www.putty.org/ putty] (Windows) oder screen (Linux) kannst du dich dann auf den Pi verbinden. |
||
− | |||
− | Nach dem Verbinden kannst du mit dem Befehl "sudo raspi-config" den Hostname ändern. |
||
− | |||
− | === Pi herunterfahren und mit dem Internet verbinden === |
||
− | |||
− | Der Pi kann nach dem Ändern des Hostname eindeutig identifiziert und daher in einem lokalen LAN betrieben werden. Fahre dazu den Pi mit <tt>sudo halt</tt> oder <tt>sudo poweroff</tt> herunter. |
||
Achtung! Ziehe nicht einfach den Netzstecker des Pi, ohne ihn korrekt herunterzufahren. Dies kann zu Beschädigungen der Hardware führen. |
Achtung! Ziehe nicht einfach den Netzstecker des Pi, ohne ihn korrekt herunterzufahren. Dies kann zu Beschädigungen der Hardware führen. |
||
− | Der Pi kann mit einem LAN-Kabel mit dem Raumnetz/LAN verbunden und damit in das Internet gebracht werden. Nach dem Start ist er unter dem neuen Namen erreichbar - Endung <tt>.local</tt> nicht vergessen. |
+ | Der Pi kann mit einem LAN-Kabel mit dem Raumnetz/LAN verbunden und damit in das Internet gebracht werden. Nach dem Start ist er unter dem neuen Namen erreichbar - Endung <tt>.local</tt> nicht vergessen. Prüfe mit <tt>ping HOSTNAME.local</tt>, ob du den Pi erreichen kannst. |
− | === Fernzugriff über eine grafische Oberfläche aktivieren === |
+ | === Fernzugriff über eine grafische Oberfläche aktivieren (VNC) === |
− | ==== |
+ | ==== Virtual Network Computing (VNC) ==== |
Mit dem VNC-Protokoll kann man über das Netzwerk auf den Bildschirm eines entfernten Rechners zugreifen. Für den Raspberry Pi ist es |
Mit dem VNC-Protokoll kann man über das Netzwerk auf den Bildschirm eines entfernten Rechners zugreifen. Für den Raspberry Pi ist es |
||
− | in der [https://www.raspberrypi. |
+ | in der [https://www.raspberrypi.com/documentation/computers/remote-access.html#vnc VNC-Dokumentation] beschrieben. |
Lade einen VNC-Viewer wie z.B. [https://www.realvnc.com/download/viewer/ RealVNC] herunter und verbinden dich mit deinem Pi. |
Lade einen VNC-Viewer wie z.B. [https://www.realvnc.com/download/viewer/ RealVNC] herunter und verbinden dich mit deinem Pi. |
||
− | |||
− | Falls das Bild zu klein ist, kann die Bildschirmauflösung über "Einstellungen → Raspberry Pi Konfiguration → Auflösung festlegen" geändert werden. Alternativ kann über SSH auf dem Pi mit dem Befehl <tt>vncserver</tt> ein virtueller Bildschirm erzeugt werden. Auf diesen kann man sich mit <tt>meinraspberrypi.local:1</tt> verbinden. |
||
Neben der Bildübertragung bietet der Zugriff über VNC auch die Möglichkeit, Dateien zu übertragen. |
Neben der Bildübertragung bietet der Zugriff über VNC auch die Möglichkeit, Dateien zu übertragen. |
||
+ | Wenn die Verbindung scheitert, muss der VNC-Server aktiviert werden. Dies ist in der [https://www.raspberrypi.com/documentation/computers/remote-access.html#vnc Dokumentation] unter "Enabling the VNC Server" beschrieben. |
||
− | ==== Option 2: Remote Desktop Protokoll (RDP) ==== |
||
+ | Sollte die Fehlermeldung "Cannot currently show the desktop" auftauchen, muss die Auflösung in der raspi-config unter "Advanced Options" → "Resolution" geändert werden. Vermutlich ist die eingestellte Auflösung zu gering. [https://www.tomshardware.com/how-to/fix-cannot-currently-show-desktop-error-raspberry-pi] |
||
− | Nutze diese Option nur, wenn die erste Option nicht funktioniert! |
||
+ | Falls das Bild zu klein ist, kann die Bildschirmauflösung über "Einstellungen → Raspberry Pi Konfiguration → Auflösung festlegen" geändert werden. Alternativ kann über SSH auf dem Pi mit dem Befehl <tt>vncserver</tt> ein virtueller Bildschirm erzeugt werden. Auf diesen kann man sich mit <tt>HOSTNAME.local:1</tt> verbinden. |
||
− | Das "Remote Desktop Protocol" erlaubt die Steuerung des Pi über eine grafische Oberfläche. Dafür muss der Dienst "xrdp" auf dem Pi installiert werden. Als Client für den Zugriff gibt es unter Windows die "Remote Desktop-Verbindung" und unter Linux "rdesktop". |
||
+ | ===== Probleme mit VNC ===== |
||
− | Bei der aktuellen Version von Raspbian wird der RealVNC-Server mitinstalliert, der nicht mit xrdp zusammenarbeitet. Daher ist '''vor''' der Installation von xrdp eine Deinstallation des VNC-Servers notwendig. |
||
+ | In der aktuellen Version von Raspberry Pi OS (Stand Dezember 2023) gibt es Probleme mit dem wayland Window Manager und VNC [https://help.realvnc.com/hc/en-us/articles/14110635000221-Raspberry-Pi-5-Bookworm-and-RealVNC-Connect]. Mit dieser Vorgehensweise sollte VNC benutzbar sein. Alles muss über SSH ausgeführt werden: |
||
− | $ sudo apt-get remove realvnc-vnc-server xrdp |
||
+ | :sudo raspi-config → Advanced Options → Wayland → X11 window manager |
||
− | Nun kann xrdp installiert werden. Hierfür ist eine Verbindung mit dem Internet notwendig. Ob eine solche Verbindung besteht, kann z.B. mit <tt>ping 8.8.8.8</tt> (Ping an einen DNS-Server von Google) geprüft werden - Abbruch mit STRG-C. Wenn die Internetverbindung besteht, erfolgt die Installation mit dem folgenden Befehl. |
||
+ | :sudo raspi-config → Interface Options → VNC → YES → finish |
||
+ | :sudo raspi-config → Display Options → VNC Resolution → Auflösung auswählen, die etwas kleiner ist als die Auflösung des eigenen Laptops (z.B. 1024x768) → finish → reboot |
||
+ | :sudo raspi-config → System Options → Boot / Auto login → Desktop (requiring user to login) → finish → reboot |
||
+ | In einem [https://forums.raspberrypi.com/viewtopic.php?t=357582 Forumspost (Oktober 2023)] wird auch der alternative VNC-Viewer [https://tigervnc.org/ tigerVNC] empfohlen. |
||
− | $ sudo apt-get install xrdp |
||
+ | Sollte auch dies nicht funktionieren, kann eine alte Version von Pi OS installiert werden. Im Pi Imager ist diese über "Raspberry Pi OS (other)" → "Raspberry Pi OS (Legacy) Full" verfügbar. |
||
− | === Passwort ändern === |
||
− | |||
− | Verbinde dich mit dem Pi und ändere das Passwort. Notiere es und merke es dir gut. Dies kannst du mit "passwd pi" oder "raspi-config" tun. |
||
− | |||
− | === Installiere das Paket espeak und die Sprachfiles (optional) === |
||
− | |||
− | Mit diesem optionalen Schritt wird der Pi um eine Sprachausgabe erweitert. |
||
− | |||
− | $ sudo apt-get install espeak espeak-data |
||
− | |||
− | Über die Audioausgabe kann der Pi seine eigene IP-Adresse ausgeben, damit wir ihn im Netz wiederfinden, ohne einen Monitor jedesmal anschließen zu müssen. Die Anleitung [[IP-Sprachausgabe einrichten]], beschreibt das genauere Vorgehen. |
||
− | |||
− | === Probleme?=== |
||
− | Notiere bei Problemen die genaue Fehlermeldung oder mache ein Bild davon. Beschreibe auch, welche Schritte du gemacht hast. |
||
== Hallo Welt: Eine blinkende LED == |
== Hallo Welt: Eine blinkende LED == |
||
Zeile 188: | Zeile 125: | ||
Hast du die richtigen Bauteile ausgewählt, kannst du die folgende Schaltung auf dem Steckbrett aufbauen. |
Hast du die richtigen Bauteile ausgewählt, kannst du die folgende Schaltung auf dem Steckbrett aufbauen. |
||
− | [[Datei:Ledschaltung.png]] |
+ | [[Datei:Ledschaltung.png|200px]] |
Um die Pins am Raspberry Pi richtig abzuzählen, informiere dich auf https://pinout.xyz über die Pinbelegung. Achte darauf, dass du die Pins 2 und 4 (mit 5 V) '''nicht''' versehentlich verwendest. |
Um die Pins am Raspberry Pi richtig abzuzählen, informiere dich auf https://pinout.xyz über die Pinbelegung. Achte darauf, dass du die Pins 2 und 4 (mit 5 V) '''nicht''' versehentlich verwendest. |
||
Zeile 198: | Zeile 135: | ||
=== Wie funktioniert die Schaltung? === |
=== Wie funktioniert die Schaltung? === |
||
− | Die Leuchtdiode benötigt zum Leuchten eine elektrische Spannung. Um den Strom zu begrenzen, muss zusätzlich ein Vorwiderstand in Reihe geschaltet werden. Die Spannung kommt vom Raspberry Pi. Pin |
+ | Die Leuchtdiode benötigt zum Leuchten eine elektrische Spannung. Um den Strom zu begrenzen, muss zusätzlich ein Vorwiderstand in Reihe geschaltet werden. Die Spannung kommt vom Raspberry Pi. Pin 7 ist ein GPIO-Pin, der sich über ein kleines Python-Programm ein- oder ausschalten lässt. Der Stromkreis wird über den Masse-Pin (Ground, GND) Pin 39 geschlossen. Da der Strom nur in eine Richtung durch die LED fließen kann, musst du darauf achten, dass die LED richtig herum in der Schaltung steckt. |
=== Das Programm === |
=== Das Programm === |
||
Zeile 204: | Zeile 141: | ||
Mit folgendem Programmtext kannst du die Schaltung testen: |
Mit folgendem Programmtext kannst du die Schaltung testen: |
||
− | + | from gpiozero import LED |
|
import time |
import time |
||
+ | print("Hallo Welt!") |
||
− | |||
− | + | led = LED(4) # GPIO4 (Pin 7) |
|
− | + | while True: |
|
− | + | led.on() # LED an |
|
+ | print("blink") |
||
− | GPIO.setup(LED, GPIO.OUT) # LED-Pin als Ausgang |
||
+ | time.sleep(0.5) |
||
− | |||
+ | led.off() # LED aus |
||
− | print("Hallo Welt") |
||
+ | time.sleep(1) |
||
− | |||
− | try: |
||
− | while True: |
||
− | GPIO.output(LED, True) # LED an |
||
− | print("blink") |
||
− | time.sleep(0.5) |
||
− | GPIO.output(LED, False) # LED aus |
||
− | time.sleep(1) |
||
− | except KeyboardInterrupt: |
||
− | GPIO.cleanup() |
||
=== Und jetzt? === |
=== Und jetzt? === |
||
Zeile 229: | Zeile 157: | ||
* Verändere die Blink-Geschwindigkeit der LED. Wie schnell kannst du sie maximal blinken lassen? |
* Verändere die Blink-Geschwindigkeit der LED. Wie schnell kannst du sie maximal blinken lassen? |
||
* Erweitere die Schaltung um eine weitere LED. |
* Erweitere die Schaltung um eine weitere LED. |
||
− | * Lass |
+ | * Lass zwei Leuchtdioden im Gegentakt blinken. |
+ | |||
− | * Es gibt einen [https://tbs1-bo.github.io/hardware-101/raspi/ kleinen Infozettel], den du ausdrucken und dem RaspberryPi beilegen kannst. Darauf findest du die wichtigsten Informationen zur Hardware-Ansteuerung. |
||
+ | == Tastereingabe == |
||
+ | In einem zweiten kleinen Projekt soll Erkannt werden, ob ein Taster betätigt ist oder nicht. Du benötigst dafür folgendes Zubehör: |
||
+ | * 1 Breadboard |
||
+ | * 3 Jumper-Wire (Female-Male) |
||
+ | * 1 Widerstand mit 1 kΩ |
||
+ | * 1 Widerstand mit 10 kΩ |
||
+ | * 1 Taster |
||
+ | |||
+ | Hast du die richtigen Bauteile ausgewählt, kannst du die folgende Schaltung auf dem Steckbrett aufbauen. |
||
+ | |||
+ | [[Datei:Taster_Schaltung.png|250px]] |
||
+ | |||
+ | Beginne mit dem Taster. Platziere den Taster so, wie auf folgendem Bild dargestellt. |
||
+ | |||
+ | [[Datei:Taster_auf_Breadboard.png|700px]] |
||
+ | |||
+ | === Das Programm === |
||
+ | |||
+ | Mit folgendem Programmtext kannst du die Schaltung testen: |
||
+ | |||
+ | from gpiozero import Button |
||
+ | import time |
||
+ | button = Button(23, pull_up=None, active_state=True) # GPIO23 (Pin 16) |
||
+ | while True: |
||
+ | if button.is_pressed: # Taster betätigt? |
||
+ | print("Der Taster ist betätigt.") |
||
+ | else: |
||
+ | print("Der Taster ist nicht betätigt") |
||
+ | time.sleep(0.5) |
||
+ | |||
+ | === Und jetzt? === |
||
+ | |||
+ | Hier ein paar Vorschläge: |
||
+ | * Programmiere einen Counter der zählt und ausgibt, wie häufig der Taster betätigt wurde. |
||
+ | * Kombiniere die Taster-Schaltung mit der LED-Schaltung. |
||
+ | * Lass die LED leuchten, wenn der Taster betätigt ist. |
||
+ | |||
+ | == CheatSheet == |
||
+ | Es gibt einen [https://tbs1-bo.github.io/hardware-101/raspi/ kleinen Infozettel], den du ausdrucken und dem RaspberryPi beilegen kannst. Darauf findest du die wichtigsten Informationen zur Hardware-Ansteuerung. |
||
== Eingabe-Ausgabe-Modul == |
== Eingabe-Ausgabe-Modul == |
||
Zeile 252: | Zeile 219: | ||
* [https://www.raspberrypi.org/magpi-issues/MagPi36.pdf The MagPi (Ausgabe 36)] - in dieser Ausgabe werden die ersten Schritte mit dem Raspberry Pi ab Seite 16 ausführlich beschrieben. |
* [https://www.raspberrypi.org/magpi-issues/MagPi36.pdf The MagPi (Ausgabe 36)] - in dieser Ausgabe werden die ersten Schritte mit dem Raspberry Pi ab Seite 16 ausführlich beschrieben. |
||
* [https://www.rheinwerk-verlag.de/raspberry-pi_3872/ Raspberry Pi - Das umfassende Handbuch] ist ein dickes Buch über den Raspberry Pi. Die ersten Kapitel stellt der Verlag kostenlos zur Verfügung. Für den Einstieg reichen sie. Die Schule hat eine Ausgabe in der IT-Bibliothek im Raum zwischen R.44 und R.46 deponiert. |
* [https://www.rheinwerk-verlag.de/raspberry-pi_3872/ Raspberry Pi - Das umfassende Handbuch] ist ein dickes Buch über den Raspberry Pi. Die ersten Kapitel stellt der Verlag kostenlos zur Verfügung. Für den Einstieg reichen sie. Die Schule hat eine Ausgabe in der IT-Bibliothek im Raum zwischen R.44 und R.46 deponiert. |
||
− | * [https://medienistik.wordpress.com/2013/03/27/neues-themenheft-unterrichten-mit-dem-raspberry-pi/ Kostenloses Themenheft: Unterrichten mit dem Raspberry Pi] |
||
* [http://pinout.xyz/ pinout.xyz] zeigt die Pin-Belegung der GPIO-Pins des Pi zusammen mit typischen Code-Schnipseln in Python. |
* [http://pinout.xyz/ pinout.xyz] zeigt die Pin-Belegung der GPIO-Pins des Pi zusammen mit typischen Code-Schnipseln in Python. |
||
* Materialien von [https://www.bakera.de/schule:raspberry_pi Herrn Bakera] und [https://elektro.schule/doku.php/raspberry Herrn Gummlich] |
* Materialien von [https://www.bakera.de/schule:raspberry_pi Herrn Bakera] und [https://elektro.schule/doku.php/raspberry Herrn Gummlich] |
||
+ | * [https://www.youtube.com/watch?v=zumnEOAk9aI How To Remotely Access The Raspberry Pi Via Bluetooth (SSH/VNC)] (Video) |
||
− | * Die grundlegende Softwareinstallation kann auch über das Projekt [https://github.com/tbs1-bo/rpi-provision rpi-provision] erzielt werden. |
||
+ | * [https://dietpi.com/ dietpi] ist ein minimales Betriebssystem für den Pi |
||
− | * Mit [http://www.pibakery.org/ PiBakery] können vorkonfigurierte Raspian Images erstellt werden. |
Aktuelle Version vom 4. Oktober 2024, 09:34 Uhr
Der Raspberry Pi ist ein kleiner und kostengünstiger Einplatinencomputer. Er wird während der Ausbildung in verschiedenen Bereichen eingesetzt.
Inhaltsverzeichnis
Beschaffung
Für den Einsatz eines Raspberry Pi im Unterricht werden folgende Komponenten zwingend benötigt:
- Raspberry Pi 4B (kleinste Ausstattung ist ausreichend, ca. 45 €)
- Gehäuse für den Raspberry Pi (die 40 Pins der GPIO-Schnittstelle müssen von oben gut zugänglich sein). Ein paar Beispiele:
- Pibow 3 Ninja Coupé (Schichtgehäuse) (ca. 10 €)
- Mepro Enclosure Case (Schichtgehäuse) (ca. 7 €)
- OneNineDesign Gehäuse (ca. 6 €)
- USB-C Steckernetzteil (2 A, ca. 8 €) (Informationen zu den Netzteilen)
- Adapter von USB auf Ethernet
- microSD-Karte Class 10 mit mindestens 16 GB Speicher. (ca. 5 €)
- Eine Analyse verschiedener Karten gibt es bei elinux.org und bei raspberrypi.org.
Folgende Ergänzungen stehen entweder bereits durch andere Elektronikgeräte wie PCs, Smartphones, Tablets und Digitalkameras zur Verfügung oder müssen neu angeschafft werden.
- Netzwerkkabel (ca. 3 €)
Für die praktische Arbeit mit den GPIO-Pins des Pi müssen folgende Komponenten beschafft werden:
- Box zur Aufbewahrung von Kleinteilen
- Experimentierboard "Breadboard" mit ca. 830 Kontakten (ca. 3 €)
- Steckbrücken "jumper wire" (ca. 4 €)
- Benötigt werden ca. 10 Stück in alle Varianten: männlich-weiblich, weiblich-weiblich, männlich-männlich. Häufig sind Bündel mit 40 Stück erhältlich, die auf 4 Schüler aufgeteilt werden können.
Optional kann ein HDMI-USB-Dongle für das Debugging hilfreich sein. Dieses Video (mirror) beschreibt die Funktion.
Bezugsquellen
Für den Versand bieten sich folgende Händler an: reichelt elektronik, Alternate, Pollin Electronic oder Conrad. Da die Preise schwanken, lohnt sich ein Vergleich. Auf den Shop-Seiten kann man nach "Starterkit" oder "Bundle" suchen, um Komplettangebote zu erhalten.
Vor der Bestellung bei Amazon-Händlern sollte darauf geachtet werden, aus welchem Land die Teile verschickt werden. Bei außereuropäischen Händlern sind lange Lieferzeiten einzuplanen.
Die offiziellen Seite von Raspberry Pi Foundation verlinkt verschiedene Shops.
Wenn sich mehrere Besteller:innen zusammentun, können hierdurch zusätzlich Versandkosten eingespart werden.
Inbetriebnahme
Diese Anleitung geht davon aus, dass Sie entweder mindestens Windows 10 oder ein aktuellen Linux- oder MacOS-Betriebssystem verwenden.
Vor dem ersten Einsatz, muss auf dem Raspberry Pi ein Betriebssystem auf einer SD-Karte installiert werden.
Führe die folgenden Schritte nacheinander durch.
Zusammenbau des Raspberry Pi
Baue das Gehäuse und den Pi zusammen. Lege SD-Karte, SD-Kartenleser, USB-Ethernet-Adapter und Netzteil bereit.
Betriebssystem installieren und Basiskonfiguration
Nutze den Raspberry Pi Imager und installiere das Betriebssystem "Raspberry Pi OS". Ein Anleitung findest du hier.
Nimm über den Button "Einstellungen bearbeiten" folgende Einstellungen vor (sollte die Optionen fehlen, kann Sie über Strg-Shift X eingeblendet werden):
- Hostname festlegen: Dies ist der Name des Pi, über den er im Netz zu finden ist. Wähle einen eindeutigen Namen. Verzichte auf Leerzeichen und Umlaute im Hostnamen und verwende am besten nur Klein- und Großbuchstaben ohne öäüß. Er darf nicht wie dein Laptop heißen.
- SSH aktivieren: SSH (Secure SHell) ermöglicht, den sicheren Zugriff auf die Kommandozeile eines Rechners.
- Benutzername und Passwort setzen: WICHTIG! Notiere diese Daten.
- WiFi einrichten mit den Zugangsdaten des Schul-WLAN
Notiere alle vorgenommenen Einstellungen (Hostname, Benutzername, Passwort, Wifi-Zugangsdaten) in einem Dokument und verwahre es sicher.
Funktionsprüfung
- Schließe den Pi mit einem Netzteil an eine Steckdose an.
- Verbinde ihn mit einem Ethernetkabel direkt mit dem PC/Laptop. Zwei LED an den Ethernetbuchse des Pi zeigen an, ob eine Verbindung besteht.
- Öffne ein Terminal oder die Powershell und versuche ihn mit ping HOSTNAME.local zu erreichen.
Hinweis: Bei manchen Windowsversionen funktioniert der direkte Zugriff ggf. über den Hostnamen nicht mehr. Durch die Eingabe von ping -4 HOSTNAME.local in der Eingabeaufforderung, erhält man die IPv4 Adresse des Raspberry Pi. Mit dieser IP-Adresse ist der Fernzugriff möglich. - Wenn alles geklappt hat, bekommst du eine Antwort vom Pi. Sollte es nicht sofort klappen, hab etwas Geduld! Der erste Start des neuen Betriebssystems dauert etwas länger. Erst wenn der "ping" funktioniert, kannst du fortfahren.
- Verbindung mit SSH: Öffne die Powershell(Windows) oder ein Terminal (Linux, MacOS) und stelle eine Verbindung mit ssh BENUTZERNAME@HOSTNAME.local her.
Pi herunterfahren und mit dem Internet verbinden
Der Pi kann nach dem Ändern des Hostname eindeutig identifiziert und daher in einem lokalen LAN oder im WLAN betrieben werden. Fahre dazu den Pi mit sudo halt oder sudo poweroff herunter.
Achtung! Ziehe nicht einfach den Netzstecker des Pi, ohne ihn korrekt herunterzufahren. Dies kann zu Beschädigungen der Hardware führen.
Der Pi kann mit einem LAN-Kabel mit dem Raumnetz/LAN verbunden und damit in das Internet gebracht werden. Nach dem Start ist er unter dem neuen Namen erreichbar - Endung .local nicht vergessen. Prüfe mit ping HOSTNAME.local, ob du den Pi erreichen kannst.
Fernzugriff über eine grafische Oberfläche aktivieren (VNC)
Virtual Network Computing (VNC)
Mit dem VNC-Protokoll kann man über das Netzwerk auf den Bildschirm eines entfernten Rechners zugreifen. Für den Raspberry Pi ist es in der VNC-Dokumentation beschrieben.
Lade einen VNC-Viewer wie z.B. RealVNC herunter und verbinden dich mit deinem Pi.
Neben der Bildübertragung bietet der Zugriff über VNC auch die Möglichkeit, Dateien zu übertragen.
Wenn die Verbindung scheitert, muss der VNC-Server aktiviert werden. Dies ist in der Dokumentation unter "Enabling the VNC Server" beschrieben.
Sollte die Fehlermeldung "Cannot currently show the desktop" auftauchen, muss die Auflösung in der raspi-config unter "Advanced Options" → "Resolution" geändert werden. Vermutlich ist die eingestellte Auflösung zu gering. [1]
Falls das Bild zu klein ist, kann die Bildschirmauflösung über "Einstellungen → Raspberry Pi Konfiguration → Auflösung festlegen" geändert werden. Alternativ kann über SSH auf dem Pi mit dem Befehl vncserver ein virtueller Bildschirm erzeugt werden. Auf diesen kann man sich mit HOSTNAME.local:1 verbinden.
Probleme mit VNC
In der aktuellen Version von Raspberry Pi OS (Stand Dezember 2023) gibt es Probleme mit dem wayland Window Manager und VNC [2]. Mit dieser Vorgehensweise sollte VNC benutzbar sein. Alles muss über SSH ausgeführt werden:
- sudo raspi-config → Advanced Options → Wayland → X11 window manager
- sudo raspi-config → Interface Options → VNC → YES → finish
- sudo raspi-config → Display Options → VNC Resolution → Auflösung auswählen, die etwas kleiner ist als die Auflösung des eigenen Laptops (z.B. 1024x768) → finish → reboot
- sudo raspi-config → System Options → Boot / Auto login → Desktop (requiring user to login) → finish → reboot
In einem Forumspost (Oktober 2023) wird auch der alternative VNC-Viewer tigerVNC empfohlen.
Sollte auch dies nicht funktionieren, kann eine alte Version von Pi OS installiert werden. Im Pi Imager ist diese über "Raspberry Pi OS (other)" → "Raspberry Pi OS (Legacy) Full" verfügbar.
Hallo Welt: Eine blinkende LED
In deinem ersten kleinen Projekt soll eine LED zum Blinken gebracht werden. Du benötigst dafür folgendes Zubehör:
- 1 Breadboard
- 2 Jumper-Wire (Female-Male)
- 1 Widerstand mit 150 Ω
- 1 Leuchtdiode (LED) der Farbe deiner Wahl
Wähle den richtigen Widerstand aus. Überlege, welche Farbringe auf dem Bauteil sein müssen. Überprüfe deine Auswahl durch eine Widerstandsmessung mit dem Multimeter.
Hast du die richtigen Bauteile ausgewählt, kannst du die folgende Schaltung auf dem Steckbrett aufbauen.
Um die Pins am Raspberry Pi richtig abzuzählen, informiere dich auf https://pinout.xyz über die Pinbelegung. Achte darauf, dass du die Pins 2 und 4 (mit 5 V) nicht versehentlich verwendest.
Auf dem Steckbrett stehen viele Kontakte für den Aufbau der Schaltung zur Verfügung. In jeden Kontakt passt ein Beinchen eines Bauteils. Manche Kontakte sind miteinander verbunden. Schaue dir folgendes Bild an, um herauszufinden, wie dein Steckbrett von innen aussieht.
Wie funktioniert die Schaltung?
Die Leuchtdiode benötigt zum Leuchten eine elektrische Spannung. Um den Strom zu begrenzen, muss zusätzlich ein Vorwiderstand in Reihe geschaltet werden. Die Spannung kommt vom Raspberry Pi. Pin 7 ist ein GPIO-Pin, der sich über ein kleines Python-Programm ein- oder ausschalten lässt. Der Stromkreis wird über den Masse-Pin (Ground, GND) Pin 39 geschlossen. Da der Strom nur in eine Richtung durch die LED fließen kann, musst du darauf achten, dass die LED richtig herum in der Schaltung steckt.
Das Programm
Mit folgendem Programmtext kannst du die Schaltung testen:
from gpiozero import LED import time print("Hallo Welt!") led = LED(4) # GPIO4 (Pin 7) while True: led.on() # LED an print("blink") time.sleep(0.5) led.off() # LED aus time.sleep(1)
Und jetzt?
Hier ein paar Vorschläge:
- Verändere die Blink-Geschwindigkeit der LED. Wie schnell kannst du sie maximal blinken lassen?
- Erweitere die Schaltung um eine weitere LED.
- Lass zwei Leuchtdioden im Gegentakt blinken.
Tastereingabe
In einem zweiten kleinen Projekt soll Erkannt werden, ob ein Taster betätigt ist oder nicht. Du benötigst dafür folgendes Zubehör:
- 1 Breadboard
- 3 Jumper-Wire (Female-Male)
- 1 Widerstand mit 1 kΩ
- 1 Widerstand mit 10 kΩ
- 1 Taster
Hast du die richtigen Bauteile ausgewählt, kannst du die folgende Schaltung auf dem Steckbrett aufbauen.
Beginne mit dem Taster. Platziere den Taster so, wie auf folgendem Bild dargestellt.
Das Programm
Mit folgendem Programmtext kannst du die Schaltung testen:
from gpiozero import Button import time button = Button(23, pull_up=None, active_state=True) # GPIO23 (Pin 16) while True: if button.is_pressed: # Taster betätigt? print("Der Taster ist betätigt.") else: print("Der Taster ist nicht betätigt") time.sleep(0.5)
Und jetzt?
Hier ein paar Vorschläge:
- Programmiere einen Counter der zählt und ausgibt, wie häufig der Taster betätigt wurde.
- Kombiniere die Taster-Schaltung mit der LED-Schaltung.
- Lass die LED leuchten, wenn der Taster betätigt ist.
CheatSheet
Es gibt einen kleinen Infozettel, den du ausdrucken und dem RaspberryPi beilegen kannst. Darauf findest du die wichtigsten Informationen zur Hardware-Ansteuerung.
Eingabe-Ausgabe-Modul
Im Unterricht wird ein Eingabe-Ausgabe-Hardware-Modul erstellt und über Software angesteuert. Viele Informationen darüber inkl. einer Dokumentation ist unter dem Projektnamen eapi bei github verfügbar.
Das E/A-Modul ist eine kleine Platine, die über zwei Taster für Eingaben und drei Leuchtdioden (rot, gelb und grün) für Ausgaben verfügt. Die Ansteuerung erfolgt über die GPIO-Schnittstelle des Raspberry Pi. Es wird an fünf GPIO-Pins des PI angeschlossen und benötigt zusätzlich einen 3,3-V-Pin und einen Masse-Pin für die Spannungsversorgung.
Die Software liegt als Modul im Python-Package-Index (PyPi) unter dem Namen eapi. Sie kann mit pip3 install eapi installiert werden. Wenn die Installation nur lokal für einen User erfolgen soll, heißt der Befehl pip3 install --user eapi.
Links
- Webseite von RaspberryPi
- Raspberry Pi Imager ist ein Tool, das bei vielen der oben genannten Schritte weiterhilft. Mit CTRL-SHIFT-X öffnet sich eine Oberfläche, über die Hostname, WiFi-Zugang, Passwort etc. konfiguriert werden können. In c't uplink 37.8 (ab 24:45) wird das Vorgehen vorgestellt.
- Raspbian - Das Betriebssystem für den RaspberryPi. Es basiert auf dem Betriebssystem Debian.
- Win32 Disk Imager schreibt unter Windows Disk-Images auf SD-Karten. Unter Linux klappt dies mit dem dd-Befehl.
- Raspberry Pi bei Wikipedia
- The MagPi (Ausgabe 36) - in dieser Ausgabe werden die ersten Schritte mit dem Raspberry Pi ab Seite 16 ausführlich beschrieben.
- Raspberry Pi - Das umfassende Handbuch ist ein dickes Buch über den Raspberry Pi. Die ersten Kapitel stellt der Verlag kostenlos zur Verfügung. Für den Einstieg reichen sie. Die Schule hat eine Ausgabe in der IT-Bibliothek im Raum zwischen R.44 und R.46 deponiert.
- pinout.xyz zeigt die Pin-Belegung der GPIO-Pins des Pi zusammen mit typischen Code-Schnipseln in Python.
- Materialien von Herrn Bakera und Herrn Gummlich
- How To Remotely Access The Raspberry Pi Via Bluetooth (SSH/VNC) (Video)
- dietpi ist ein minimales Betriebssystem für den Pi