Skip to content

Commit

Permalink
Made timeouts exponential (#640)
Browse files Browse the repository at this point in the history
* Made timeouts exponential using RetryNWithBackoff
* Simplified ENI network setup
* TestSetupENINetwork Fix

Signed-off-by: bpopovschi <zyqsempai@mail.ru>
  • Loading branch information
Zyqsempai authored and Claes Mogren committed Oct 29, 2019
1 parent 0497f48 commit 1ee59a0
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 30 deletions.
41 changes: 13 additions & 28 deletions pkg/networkutils/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,8 @@ import (
"syscall"
"time"

"github.com/aws/amazon-vpc-cni-k8s/pkg/utils/retry"

"github.com/pkg/errors"
"golang.org/x/sys/unix"

Expand Down Expand Up @@ -759,35 +761,18 @@ func setupENINetwork(eniIP string, eniMAC string, eniTable int, eniSubnetCIDR st
return errors.Wrap(err, "setupENINetwork: failed to clean up old routes")
}

// In case of route dependency, retry few times
retry := 0
for {
if err := netLink.RouteAdd(&r); err != nil {
if netlinkwrapper.IsNetworkUnreachableError(err) {
retry++
if retry > maxRetryRouteAdd {
log.Errorf("Failed to add route %s/0 via %s table %d",
r.Dst.IP.String(), gw.String(), eniTable)
return errors.Wrapf(err, "setupENINetwork: failed to add route %s/0 via %s table %d",
r.Dst.IP.String(), gw.String(), eniTable)
}
log.Debugf("Not able to add route route %s/0 via %s table %d (attempt %d/%d)",
r.Dst.IP.String(), gw.String(), eniTable, retry, maxRetryRouteAdd)
time.Sleep(retryRouteAddInterval)
} else if netlinkwrapper.IsRouteExistsError(err) {
if err := netLink.RouteReplace(&r); err != nil {
return errors.Wrapf(err, "setupENINetwork: unable to replace route entry %s", r.Dst.IP.String())
}
log.Debugf("Successfully replaced route to be %s/0", r.Dst.IP.String())
break
} else {
return errors.Wrapf(err, "setupENINetwork: unable to add route %s/0 via %s table %d",
r.Dst.IP.String(), gw.String(), eniTable)
}
} else {
log.Debugf("Successfully added route route %s/0 via %s table %d", r.Dst.IP.String(), gw.String(), eniTable)
break
err = retry.RetryNWithBackoff(retry.NewSimpleBackoff(500*time.Millisecond, retryRouteAddInterval, 0.15, 2.0), maxRetryRouteAdd, func() error {
if err := netLink.RouteReplace(&r); err != nil {
log.Debugf("Not able to set route %s/0 via %s table %d",
r.Dst.IP.String(), gw.String(), eniTable)
return errors.Wrapf(err, "setupENINetwork: unable to replace route entry %s", r.Dst.IP.String())
}

log.Debugf("Successfully added/replaced route to be %s/0", r.Dst.IP.String())
return nil
})
if err != nil {
return err
}
}

Expand Down
4 changes: 2 additions & 2 deletions pkg/networkutils/network_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -106,10 +106,10 @@ func TestSetupENINetwork(t *testing.T) {
mockNetLink.EXPECT().AddrAdd(gomock.Any(), &netlink.Addr{IPNet: testeniAddr}).Return(nil)

mockNetLink.EXPECT().RouteDel(gomock.Any())
mockNetLink.EXPECT().RouteAdd(gomock.Any()).Return(nil)
mockNetLink.EXPECT().RouteReplace(gomock.Any()).Return(nil)

mockNetLink.EXPECT().RouteDel(gomock.Any())
mockNetLink.EXPECT().RouteAdd(gomock.Any()).Return(nil)
mockNetLink.EXPECT().RouteReplace(gomock.Any()).Return(nil)

mockNetLink.EXPECT().RouteDel(gomock.Any()).Return(nil)

Expand Down

0 comments on commit 1ee59a0

Please sign in to comment.