Utilizzando questo mio software per la configurazione di rete, è molto semplice.
http://code.google.com/p/badvpn/wiki/NCD
Lo farà il seguente programma NCD. Mostra anche come estendere la configurazione, in questo caso eseguendo qualcosa quando la rete va su / giù.
process eth0 {
# Set device.
var("eth0") dev;
# Wait for device to appear, set it up, and wait for cable to be plugged in.
net.backend.waitdevice(dev);
net.up(dev);
net.backend.waitlink(dev);
# DHCP configuration.
# net.ipv4.dhcp() will block here until it obtaines an IP address.
# It doesn't check the obtained address in any way,
# so as a basic security measure, do not proceed if it is local.
net.ipv4.dhcp(dev) dhcp;
ip_in_network(dhcp.addr, "127.0.0.0", "8") test_local;
ifnot(test_local);
# Assign IP address to interface, as obtained by DHCP.
net.ipv4.addr(dev, dhcp.addr, dhcp.prefix);
# Add default route.
net.ipv4.route("0.0.0.0", "0", dhcp.gateway, "20", dev);
# Add DNS servers.
net.dns(dhcp.dns_servers, "20");
# Run an external program when network comes up or goes down.
list("/some/program/to/run/when/up", "argument") do;
list("/some/program/to/run/when/down", "argument") undo;
run(do, undo);
}
Si noti che questo non solo gestirà il cavo di rete collegato o disconnesso, ma anche l'interfaccia di rete stessa che appare e scompare (utile se è USB).
Il vantaggio dell'utilizzo di NCD rispetto ad altri software come ifplugd è che il suo design consente una grande flessibilità. Fondamentalmente ti consente di programmare la tua configurazione di rete, invece di essere limitato a un set limitato di capacità hardcoded.
AGGIORNAMENTO: ho creato pacchetti Ubuntu per BadVPN e NCD. Ho aggiornato il wiki con le istruzioni di installazione e utilizzo anche per Ubuntu: http://code.google.com/p/badvpn/wiki/NCD#Running_it
ifplugd
enetplugd
sembrano non mantenuti. Comunque questa domanda simile sembra avere una buona (semplice) risposta usando le regole udev - nessun pacchetto aggiuntivo necessario. serverfault.com/a/312296/275255