boot: checkPortAvailability() should fail only for EADDRINUSE error and ignore other errors. (#2527)

fixes #2510
This commit is contained in:
Krishna Srinivas 2016-08-22 22:50:01 +05:30 committed by Harshavardhana
parent 07506358ff
commit 45c928e2f5

View File

@ -19,6 +19,8 @@ package cmd
import (
"fmt"
"net"
"os"
"syscall"
)
// Make sure that none of the other processes are listening on the
@ -35,8 +37,14 @@ func checkPortAvailability(port int) error {
for _, n := range network {
l, err := net.Listen(n, fmt.Sprintf(":%d", port))
if err != nil {
if isAddrInUse(err) {
// Return error if another process is listening on the
// same port.
return err
}
// Ignore any other error (ex. EAFNOSUPPORT)
continue
}
// look for error so we don't have dangling connection
if err = l.Close(); err != nil {
@ -46,3 +54,18 @@ func checkPortAvailability(port int) error {
return nil
}
// Return true if err is "address already in use" error.
// syscall.EADDRINUSE is available on all OSes.
func isAddrInUse(err error) bool {
if opErr, ok := err.(*net.OpError); ok {
if sysErr, ok := opErr.Err.(*os.SyscallError); ok {
if errno, ok := sysErr.Err.(syscall.Errno); ok {
if errno == syscall.EADDRINUSE {
return true
}
}
}
}
return false
}