mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-29 14:37:00 +00:00
Move getting IP address into retry loop for agnhost/guestbook
Removes the fatal error from getIP and moves it to retry loop so that application will not immediately crash on failure. Signed-off-by: hasheddan <georgedanielmangum@gmail.com>
This commit is contained in:
parent
9081dfb68d
commit
921b76ceaa
@ -78,11 +78,18 @@ func registerNode(registerTo, port string) {
|
|||||||
|
|
||||||
hostPort := net.JoinHostPort(registerTo, backendPort)
|
hostPort := net.JoinHostPort(registerTo, backendPort)
|
||||||
|
|
||||||
request := fmt.Sprintf("register?host=%s", getIP(hostPort).String())
|
|
||||||
log.Printf("Registering to master: %s/%s", hostPort, request)
|
|
||||||
start := time.Now()
|
start := time.Now()
|
||||||
for time.Since(start) < timeout {
|
for time.Since(start) < timeout {
|
||||||
_, err := net.ResolveTCPAddr("tcp", hostPort)
|
host, err := getIP(hostPort)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("unable to get IP %s: %v. Retrying in %s.", hostPort, err, sleep)
|
||||||
|
time.Sleep(sleep)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
request := fmt.Sprintf("register?host=%s", host.String())
|
||||||
|
log.Printf("Registering to master: %s/%s", hostPort, request)
|
||||||
|
_, err = net.ResolveTCPAddr("tcp", hostPort)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("unable to resolve %s, --slaveof param and/or --backend-port param are invalid: %v. Retrying in %s.", hostPort, err, sleep)
|
log.Printf("unable to resolve %s, --slaveof param and/or --backend-port param are invalid: %v. Retrying in %s.", hostPort, err, sleep)
|
||||||
time.Sleep(sleep)
|
time.Sleep(sleep)
|
||||||
@ -287,13 +294,13 @@ func createHTTPClient(transport *http.Transport) *http.Client {
|
|||||||
return client
|
return client
|
||||||
}
|
}
|
||||||
|
|
||||||
func getIP(hostPort string) net.IP {
|
func getIP(hostPort string) (net.IP, error) {
|
||||||
conn, err := net.Dial("udp", hostPort)
|
conn, err := net.Dial("udp", hostPort)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return []byte{}, err
|
||||||
}
|
}
|
||||||
defer conn.Close()
|
defer conn.Close()
|
||||||
|
|
||||||
localAddr := conn.LocalAddr().(*net.UDPAddr)
|
localAddr := conn.LocalAddr().(*net.UDPAddr)
|
||||||
return localAddr.IP
|
return localAddr.IP, nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user