Korzystanie z mojego oprogramowania do konfiguracji sieci jest bardzo łatwe.
http://code.google.com/p/badvpn/wiki/NCD
Zrobi to następujący program NCD. Pokazuje także, w jaki sposób można rozszerzyć konfigurację, w tym przypadku uruchamiając coś, gdy sieć idzie w górę / w dół.
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);
}
Zauważ, że to nie tylko poradzi sobie z podłączaniem i odłączaniem kabla sieciowego, ale także z pojawianiem się i znikaniem samego interfejsu sieciowego (przydatne, jeśli jest to USB).
Zaletą korzystania z NCD w porównaniu do innych programów, takich jak ifplugd, jest to, że jego konstrukcja zapewnia dużą elastyczność. Zasadniczo pozwala zaprogramować własną konfigurację sieci, a nie ograniczać się do ograniczonego zestawu zakodowanych możliwości.
AKTUALIZACJA: Stworzyłem pakiety Ubuntu dla BadVPN i NCD. Zaktualizowałem wiki również instrukcjami instalacji i użytkowania Ubuntu: http://code.google.com/p/badvpn/wiki/NCD#Running_it
ifplugd
inetplugd
wydają unmaintained. Jednak to podobne pytanie wygląda na to, że ma dobrą (prostą) odpowiedź przy użyciu reguł udev - nie jest potrzebny żaden dodatkowy pakiet. serverfault.com/a/312296/275255