WakeOnLan: Unterschied zwischen den Versionen
KKeine Bearbeitungszusammenfassung |
|||
(6 dazwischenliegende Versionen von 6 Benutzern werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
Mittels Wake On Lan (WOL) können Computer, NAS usw. von einem anderen Netzwerk-Gerät eingeschaltet werden. Wake on LAN läuft auf der ISO/OSI-Schicht 2. Diese Pakete werden i.d.R. nicht geroutet. Ein Wake on Lan Paket kann entsprechend nur innerhalb eines Netzwerksegments versendet werden. Das zu weckende Gerät muss Wake on Lan unterstützen und es muss (bei PCs z.B. im BIOS oder im Treiber der Netzwerkkarte) eingeschaltet werden. Bei einigen Systemen steigt die Energieaufnahme im Standby bei aktiviertem WOL von unter einem Watt auf mehrere Watt. | |||
Wake On Lan ist auch über das FHEM-Hilfsmodul [[WOL]] unterstützt. | |||
== Ermitteln der MAC-Adresse == | == Ermitteln der MAC-Adresse == | ||
Zunächst muss die MAC-Adresse des zu weckenden Gerätes ermittelt werden. | |||
Auf dem Gerät selber: | Auf dem Gerät selber: | ||
* Auf einem Windows-PC in einer Shell den Befehl „ipconfig /all“ eingeben | * Auf einem Windows-PC in einer Shell den Befehl „ipconfig /all“ eingeben | ||
Zeile 14: | Zeile 13: | ||
== OpenWRT == | == OpenWRT == | ||
Das Wake on Lan Paket kann mit dem Programm ''etherwake'' erzeugt werden. | |||
:<code>opkg update</code> | |||
:<code>opkg install etherwake</code> | |||
Test: In der Shell folgenden Befehl eingeben (die MAC-Adresse muss natürlich angepasst werden, das Interface (hier br-lan) eventuell auch): | |||
:<code>etherwake -i br-lan 00:06:55:5a:53:f3</code> | |||
Test: In der Shell folgenden Befehl eingeben | |||
Das Gerät sollte jetzt einschalten. | Das Gerät sollte jetzt einschalten. | ||
Funktion in der Datei myUtils.pm erstellen. | Funktion in der Datei ''[[99_myUtils_anlegen|99-myUtils.pm]]'' erstellen. | ||
<pre><nowiki> | |||
######## WakeOnLan von OpenWRT ############ | |||
sub | sub | ||
WakeOnLan | WakeOnLan | ||
Zeile 34: | Zeile 31: | ||
$ret .= qx(etherwake -i br-lan $mac); | $ret .= qx(etherwake -i br-lan $mac); | ||
$ret =~ s,[\r\n]*,,g; # remove CR from return-string | $ret =~ s,[\r\n]*,,g; # remove CR from return-string | ||
Log 1, " | Log 1, "send awake to $mac: $ret"; | ||
}</nowiki> | } | ||
</nowiki></pre> | |||
Test: Im FHEM-Webinterface <code>{ WakeOnLan('00:06:55:5a:53:f3');; }</code> eingeben. | |||
Um auf einen Tasterdruck reagieren zu können, muss die [[Konfiguration]] ergänzt werden: | |||
:<code>define HM_Taster_01.ntfy notify HM_Taster_01.* {WakeOnLan('00:17:31:fa:9b:51')}</code> | |||
'''Achtung:''' Wenn FHEM nicht als root-Benutzer, sondern als normaler Benutzer gestartet wird, wird etherwake nicht direkt funktionieren: | |||
<pre> | |||
fhem@XXX:/opt/fhem$ etherwake C8:CD:72:01:FF:FF | |||
etherwake: This program must be run as root. | |||
</pre> | |||
FHEM muss nun also etherwake irgendwie mit root-Rechten starten können. Sehr einfach kann man das erreichen, indem man das SETUID-Flag auf /usr/sbin/etherwake setzt. Das führt dazu, dass das Programm immer mit dem Benutzer ausgeführt wird dem es gehört. Da das Programm nach der Installation normalerweise root gehört, haben wir mit einem einfachen chmod +s /usr/sbin/etherwake also schon unser Ziel erreicht. | |||
== Links == | |||
* {{Link2Forum|Topic=24777|LinkText=Forenthread}} zum Thema WOL | |||
[[Kategorie:Code Snippets]] | |||
Aktuelle Version vom 31. Dezember 2021, 12:21 Uhr
Mittels Wake On Lan (WOL) können Computer, NAS usw. von einem anderen Netzwerk-Gerät eingeschaltet werden. Wake on LAN läuft auf der ISO/OSI-Schicht 2. Diese Pakete werden i.d.R. nicht geroutet. Ein Wake on Lan Paket kann entsprechend nur innerhalb eines Netzwerksegments versendet werden. Das zu weckende Gerät muss Wake on Lan unterstützen und es muss (bei PCs z.B. im BIOS oder im Treiber der Netzwerkkarte) eingeschaltet werden. Bei einigen Systemen steigt die Energieaufnahme im Standby bei aktiviertem WOL von unter einem Watt auf mehrere Watt.
Wake On Lan ist auch über das FHEM-Hilfsmodul WOL unterstützt.
Ermitteln der MAC-Adresse
Zunächst muss die MAC-Adresse des zu weckenden Gerätes ermittelt werden. Auf dem Gerät selber:
- Auf einem Windows-PC in einer Shell den Befehl „ipconfig /all“ eingeben
- Auf einem Linux-PC in einer Shell den Befehl „ifconfig“ eingeben
Von einem anderen Gerät
- Auf einem Windows-PC in einer Shell den Befehl „arp -a“ eingeben
- Auf einem Linux-PC in einer Shell den Befehl „arp -a“ eingeben
OpenWRT
Das Wake on Lan Paket kann mit dem Programm etherwake erzeugt werden.
opkg update
opkg install etherwake
Test: In der Shell folgenden Befehl eingeben (die MAC-Adresse muss natürlich angepasst werden, das Interface (hier br-lan) eventuell auch):
etherwake -i br-lan 00:06:55:5a:53:f3
Das Gerät sollte jetzt einschalten.
Funktion in der Datei 99-myUtils.pm erstellen.
######## WakeOnLan von OpenWRT ############ sub WakeOnLan { my $mac = shift; my $ret = ""; $ret .= qx(etherwake -i br-lan $mac); $ret =~ s,[\r\n]*,,g; # remove CR from return-string Log 1, "send awake to $mac: $ret"; }
Test: Im FHEM-Webinterface { WakeOnLan('00:06:55:5a:53:f3');; }
eingeben.
Um auf einen Tasterdruck reagieren zu können, muss die Konfiguration ergänzt werden:
define HM_Taster_01.ntfy notify HM_Taster_01.* {WakeOnLan('00:17:31:fa:9b:51')}
Achtung: Wenn FHEM nicht als root-Benutzer, sondern als normaler Benutzer gestartet wird, wird etherwake nicht direkt funktionieren:
fhem@XXX:/opt/fhem$ etherwake C8:CD:72:01:FF:FF etherwake: This program must be run as root.
FHEM muss nun also etherwake irgendwie mit root-Rechten starten können. Sehr einfach kann man das erreichen, indem man das SETUID-Flag auf /usr/sbin/etherwake setzt. Das führt dazu, dass das Programm immer mit dem Benutzer ausgeführt wird dem es gehört. Da das Programm nach der Installation normalerweise root gehört, haben wir mit einem einfachen chmod +s /usr/sbin/etherwake also schon unser Ziel erreicht.
Links
- Forenthread zum Thema WOL