1
contributo
mNessun oggetto della modifica |
Nessun oggetto della modifica |
||
Riga 1: | Riga 1: | ||
=== | ==Introduzione== | ||
Il Wake On Lan è una funzione molto utile che permette di accendere il proprio computer a distanza dall'interno della propria rete locale. Molte schede | |||
di rete, soprattutto gli ultimi chip integrati, supportano questa caratteristica che in alcuni casi si può rivelare davvero molto utile. Immaginate ad esempio di avere due pc in due stanze/uffici diverse dello stesso piano o perché no, proprio in due piani diversi e di essere impegnati sulla prima postazione.. vi ricordate però che avete bisogno di andare a controllare un documento che sta sull'altro computer e pensate di aprire vnc ma purtroppo la seconda postazione e' ancora spenta quindi non vi potete collegare.. a questo punto solo una cosa vi può aiutare: il '''MagicPacket(tm)'''! | |||
== | |||
==Software necessario== | |||
Avremmo bisogno di due programmi: | |||
* ethtool | |||
* etherwake | |||
Per installarli è sufficiente un: | |||
<pre> | <pre> | ||
# apt-get install | # apt-get install ethtool etherwake | ||
</pre> | </pre> | ||
==Utilizzo di ethtool== | |||
All'avvio del computer entrate nel BIOS e attivate il Wake-On-Lan; solitamente trovate l'impostazione sotto la voce | |||
"Power Management Setup". | |||
Una volta avviato Linux lanciate: | |||
<pre> | <pre> | ||
# | # ethtool eth0 | ||
</pre> | </pre> | ||
{{ Warningbox | in questo e nei futuri esempi, sostituite eth0 con il nome corrispondente alla scheda di rete che state usando! }} | |||
A questo punto dovreste vedere una serie di informazioni tra cui qualcosa di simile a questo: | |||
<pre> | |||
Supports Wake-on: g | |||
Wake-on: d | |||
</pre> | |||
La voce "Supports Wake-on" specifica i metodi di wake-on supportati dalla vostra scheda di rete; se non la vedete è un brutto segno! | |||
La voce "Wake-on" specifica il metodo in uso; d sta per disabled mentre g è quello che andremo ad usare (Wake on MagicPacket(tm)). ''Se per qualche motivo avete già la voce "Wake-on" impostata a "g" potete terminare qui la lettura di questa pagina ;)'' | |||
Per impostare il metodo a "g" assicuratevi di avere la lettera "g" tra quelle che seguono la voce "Supports Wake-on" e poi digitate: | |||
<pre> | |||
# ethtool -s eth0 wol g | |||
</pre> | |||
Se rilanciate | |||
<pre> | |||
# ethtool eth0 | |||
</pre> | |||
dovreste avere "'''Wake-on: g'''". | |||
A questo punto spegnendo il computer lo potrete accendere da un'altra postazione usando etherwake. | |||
==Utilizzo di etherwake== | |||
etherwake serve per inviare il MagicPacket(tm) alla scheda di rete del pc che volete accendere, accendendolo. | |||
Ovviamente, dal momento che il pc è spento non vi potete basare sul indirizzo IP; dovrete usare il MAC Address. | |||
Per trovare il MAC Address del pc di destinazione lanciate da quest'ultimo il comando: | |||
<pre> | |||
# ifconfig | |||
</pre> | |||
ed individuate la riga: | |||
<pre> | |||
eth0 Link encap:Ethernet '''HWaddr 00:50:6D:EA:A2:DC''' | |||
</pre> | |||
Il MAC Address e' la parte che segue la dicitura "HWaddr" ovvero, nel nostro esempio, "00:50:6D:EA:A2:DC" (senza virgolette). | |||
Segnatevi il MAC Address e dopo aver impostato il metodo di wake-on a "g" sul pc di destinazione, spegnetelo e recatevi sull'altra postazione. | |||
A questo punto lanciate: | |||
<pre> | |||
# etherwake <mac address> -D | |||
esempio: | |||
# etherwake 00:50:6D:EA:A2:DC -D | |||
</pre> | |||
L'opzione -D serve solo ad avere in ouput qualche informazione in più sull'operazione. | |||
Se tutto è andato per il verso giusto, il secondo pc dovrebbe essersi acceso.. | |||
==Ultimi ritocchi== | |||
; | Ora, se il pc è partito, noterete che lanciando nuovamente "ethtool eth0" il metodo di wake-on è tornato a "d". | ||
Per far si che ogni volta che accendete il computer il metodo usato sia "g" ci sono varie strade; di seguito spiegherò quella che ho scelto ovvero | |||
la modifica del file di avvio della rete. | |||
Aprite il file '''/etc/init.d/networking''' e modificatelo come segue: | |||
<pre> | <pre> | ||
(if (is ( | #!/bin/sh | ||
# | |||
# manage network interfaces and configure some networking options | |||
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin | |||
if ! [ -x /sbin/ifup ]; then | |||
exit 0 | |||
fi | |||
spoofprotect_rp_filter () { | |||
# This is the best method: turn on Source Address Verification and get | |||
# spoof protection on all current and future interfaces. | |||
if [ -e /proc/sys/net/ipv4/conf/all/rp_filter ]; then | |||
for f in /proc/sys/net/ipv4/conf/*/rp_filter; do | |||
echo 1 > $f | |||
done | |||
return 0 | |||
else | |||
return 1 | |||
fi | |||
} | |||
spoofprotect () { | |||
echo -n "Setting up IP spoofing protection: " | |||
if spoofprotect_rp_filter; then | |||
echo "rp_filter." | |||
else | |||
echo "FAILED." | |||
fi | |||
} | |||
ip_forward () { | |||
if [ -e /proc/sys/net/ipv4/ip_forward ]; then | |||
echo -n "Enabling packet forwarding..." | |||
echo 1 > /proc/sys/net/ipv4/ip_forward | |||
echo "done." | |||
fi | |||
} | |||
syncookies () { | |||
if [ -e /proc/sys/net/ipv4/tcp_syncookies ]; then | |||
echo -n "Enabling TCP/IP SYN cookies..." | |||
echo 1 > /proc/sys/net/ipv4/tcp_syncookies | |||
echo "done." | |||
fi | |||
} | |||
doopt () { | |||
optname=$1 | |||
default=$2 | |||
opt=`grep "^$optname=" /etc/network/options` | |||
if [ -z "$opt" ]; then | |||
opt="$optname=$default" | |||
fi | |||
optval=${opt#$optname=} | |||
if [ "$optval" = "yes" ]; then | |||
eval $optname | |||
fi | |||
} | |||
case "$1" in | |||
start) | |||
doopt spoofprotect yes | |||
doopt syncookies no | |||
doopt ip_forward no | |||
echo -n "Configuring network interfaces..." | |||
ifup -a | |||
ethtool -s eth0 wol g | |||
echo "done." | |||
;; | |||
stop) | |||
if sed -n 's/^[^ ]* \([^ ]*\) \([^ ]*\) .*$/\1 \2/p' /proc/mounts | | |||
grep -q "^/ nfs$"; then | |||
echo "NOT deconfiguring network interfaces: / is an NFS mount" | |||
elif sed -n 's/^[^ ]* \([^ ]*\) \([^ ]*\) .*$/\1 \2/p' /proc/mounts | | |||
grep -q "^/ smbfs$"; then | |||
echo "NOT deconfiguring network interfaces: / is an SMB mount" | |||
elif sed -n 's/^[^ ]* \([^ ]*\) \([^ ]*\) .*$/\2/p' /proc/mounts | | |||
grep -qE '^(nfs[1234]?|smbfs|ncp|ncpfs|coda|cifs)$'; then | |||
echo "NOT deconfiguring network interfaces: network shares still mounted." | |||
else | |||
echo -n "Deconfiguring network interfaces..." | |||
ifdown -a --exclude=lo | |||
echo "done." | |||
fi | |||
;; | |||
force-reload|restart) | |||
doopt spoofprotect yes | |||
doopt syncookies no | |||
doopt ip_forward no | |||
echo -n "Reconfiguring network interfaces..." | |||
ifdown -a --exclude=lo | |||
ifup -a | |||
ethtool -s eth0 wol g | |||
echo "done." | |||
;; | |||
*) | |||
echo "Usage: /etc/init.d/networking {start|stop|restart|force-reload}" | |||
exit 1 | |||
;; | |||
esac | |||
exit 0 | |||
</pre> | </pre> | ||
Le uniche due modifiche che ho fatto sono le due aggiunte del comando '''ethtool -s eth0 wol g''' nella sezione di start e restart delle interfacce di rete. Copiate solo quel comando nel vostro file nel punto corrispondente; evitate di fare il copia e incolla dell'intero file. | |||
{{ Warningbox | gli utenti k/ubuntu hanno una versione leggermente diversa; il comando sopracitato va messo dopo il blocco "if" }} | |||
'''Esempio estratto dal file networking di kubuntu:''' | |||
<pre> | <pre> | ||
if [ "$VERBOSE" != no ]; then | |||
ifup -a | |||
else | |||
ifup -a >/dev/null 2>&1 | |||
fi | |||
ethtool -s eth0 wol g | |||
</pre> | </pre> | ||
Un | '''Metodo alternativo''' | ||
Un metodo alternativo che non richiede la modifica dello script di avvio è quello di inserire l'abilitazione della funzione wake quando l'interfaccia | |||
di rete viene tirata su. Per fare questo si può inserire l'istruzione '''ethtool -s eth0 wol g''' direttamente in '''/etc/network/interfaces'''. Ad esempio: | |||
<pre> | |||
auto eth0 | |||
iface eth0 inet static | |||
address 192.168.1.2 | |||
netmask 255.255.255.0 | |||
gateway 192.168.1.1 | |||
</pre> | |||
diventa | |||
<pre> | <pre> | ||
auto eth0 | |||
iface eth0 inet static | |||
address 192.168.1.2 | |||
netmask 255.255.255.0 | |||
gateway 192.168.1.1 | |||
up ethtool -s eth0 wol g | |||
</pre> | </pre> | ||
== | Notare l'aggiunta della direttiva '''up''' per l'interfaccia '''eth0''' | ||
==Conclusioni== | |||
La tecnologia Wake-On-Lan si può rendere utile solo nei rari casi in cui si disponga di una LAN con postazioni molto distanti tra loro, tuttavia in tali situazioni si rivela una risorsa davvero preziosa che può aiutare tra le altre cose a risparmiare energia, spegnendo i computer non usati "perchè tanto poi ...". | |||
---- | ---- [[Utente:Virtual DarKness|Virtual DarKness]] 16:58, Giu 23, 2005 (EDT) | ||
[[Categoria:Networking]] | |||
[[Categoria: |
contributo