Look for network errors appropriately for RemoteStorageAPI (#8128)

net.Error is very unreliable in providing better error
handling, we need to ensure that we always have a fallback
option in case of network failures.

This fixes an important issue in our distributed server
setups when one of the servers is down, all deployments
out there are recommended to upgrade after this fix is
merged to ensure that availability is not lost.

Fixes #8127
Fixes #8016
Fixes #7964
master
Harshavardhana 5 years ago committed by GitHub
parent d6dd98e597
commit 70136fb55b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 20
      cmd/utils.go

@ -29,6 +29,7 @@ import (
"io/ioutil" "io/ioutil"
"net" "net"
"net/http" "net/http"
"net/url"
"os" "os"
"path/filepath" "path/filepath"
"reflect" "reflect"
@ -446,10 +447,25 @@ func isNetworkOrHostDown(err error) bool {
// or a non-temporary error. // or a non-temporary error.
e, ok := err.(net.Error) e, ok := err.(net.Error)
if ok { if ok {
return e.Timeout() urlErr, ok := e.(*url.Error)
if ok {
switch urlErr.Err.(type) {
case *net.DNSError, *net.OpError, net.UnknownNetworkError:
return true
}
}
if e.Timeout() {
return true
}
} }
ok = false
// Fallback to other mechanisms. // Fallback to other mechanisms.
if strings.Contains(err.Error(), "i/o timeout") { if strings.Contains(err.Error(), "Connection closed by foreign host") {
ok = true
} else if strings.Contains(err.Error(), "TLS handshake timeout") {
// If error is - tlsHandshakeTimeoutError.
ok = true
} else if strings.Contains(err.Error(), "i/o timeout") {
// If error is - tcp timeoutError. // If error is - tcp timeoutError.
ok = true ok = true
} else if strings.Contains(err.Error(), "connection timed out") { } else if strings.Contains(err.Error(), "connection timed out") {

Loading…
Cancel
Save