]> git.ipfire.org Git - thirdparty/dracut.git/commitdiff
do 'ip route replace default' instead of 'add'
authorWill Woods <wwoods@redhat.com>
Thu, 28 Aug 2014 17:44:47 +0000 (13:44 -0400)
committerHarald Hoyer <harald@redhat.com>
Fri, 12 Sep 2014 08:22:13 +0000 (10:22 +0200)
When you define the gateway for an interface, dracut sets it up with:

  ip route add default via $gw dev $netif

If a default route is already set (e.g. if you have multiple NICs), this
will fail with the message "RTNETLINK answers: File exists".

So, if your first NIC isn't usable as a default route

Using "ip route replace default" instead allows ifup/dhclient-script to
correctly change the default route to the new interface.

modules.d/40network/dhclient-script.sh
modules.d/40network/ifup.sh

index ba05250de99218c459c8d9c865d5b2d57a87df85..885303a2c45753a39c5e4a6eae7035db33e132cd 100755 (executable)
@@ -45,7 +45,7 @@ setup_interface() {
         valid_lft ${lease_time} preferred_lft ${lease_time} \
         dev $netif
 
-    [ -n "$gw" ] && echo ip route add default via $gw dev $netif > /tmp/net.$netif.gw
+    [ -n "$gw" ] && echo ip route replace default via $gw dev $netif > /tmp/net.$netif.gw
 
     [ -n "${search}${domain}" ] && echo "search $search $domain" > /tmp/net.$netif.resolv.conf
     if  [ -n "$namesrv" ] ; then
index 43e84a2c1810861d397e16983803dd9db34272a5..67b1d9f8b628b8dfeb308258a54cef3f4262428d 100755 (executable)
@@ -145,7 +145,7 @@ do_static() {
         ip addr add $ip/$mask ${srv:+peer $srv} brd + dev $netif
     fi
 
-    [ -n "$gw" ] && echo ip route add default via $gw dev $netif > /tmp/net.$netif.gw
+    [ -n "$gw" ] && echo ip route replace default via $gw dev $netif > /tmp/net.$netif.gw
     [ -n "$hostname" ] && echo "echo $hostname > /proc/sys/kernel/hostname" > /tmp/net.$netif.hostname
 
     return 0