WakeOnLan: Unterschied zwischen den Versionen

Aus FHEMWiki
Keine Bearbeitungszusammenfassung
KKeine Bearbeitungszusammenfassung
 
(9 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.


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 (im BIOS) eingeschaltet werden.
== Ermitteln der MAC-Adresse ==
== Ermitteln der MAC-Adresse ==
 
Zunächst muss die MAC-Adresse des zu weckenden Gerätes ermittelt werden.  
Anschließend 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>


Das Wake on Lan Paket kann mit dem Programm etherwake erzeugt werden.
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>
<nowiki>opkg update
opkg install etherwake</nowiki>
 
Test:
  <nowiki>etherwake 00:06:55:5a:53:f3</nowiki>
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>
<nowiki>######## WakeOnLan von OpenWRT ############  
######## WakeOnLan von OpenWRT ############  
sub  
sub  
WakeOnLan
WakeOnLan
{  
{  
  my $mac = shift;
  my $mac = shift;
  $ret .= qx(etherwake $mac);
my $ret = "";
  $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, "sendEmail to $mac returned: $ret";  
  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, 13: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