Fix reconnection when vCenter is rebooted (#6085)
This commit is contained in:
		
							parent
							
								
									f46a9c02c6
								
							
						
					
					
						commit
						10c31ca209
					
				|  | @ -61,6 +61,8 @@ func NewClientFactory(ctx context.Context, url *url.URL, parent *VSphere) *Clien | ||||||
| func (cf *ClientFactory) GetClient(ctx context.Context) (*Client, error) { | func (cf *ClientFactory) GetClient(ctx context.Context) (*Client, error) { | ||||||
| 	cf.mux.Lock() | 	cf.mux.Lock() | ||||||
| 	defer cf.mux.Unlock() | 	defer cf.mux.Unlock() | ||||||
|  | 	retrying := false | ||||||
|  | 	for { | ||||||
| 		if cf.client == nil { | 		if cf.client == nil { | ||||||
| 			var err error | 			var err error | ||||||
| 			if cf.client, err = NewClient(ctx, cf.url, cf.parent); err != nil { | 			if cf.client, err = NewClient(ctx, cf.url, cf.parent); err != nil { | ||||||
|  | @ -77,12 +79,21 @@ func (cf *ClientFactory) GetClient(ctx context.Context) (*Client, error) { | ||||||
| 			log.Printf("I! [inputs.vsphere]: Client session seems to have time out. Reauthenticating!") | 			log.Printf("I! [inputs.vsphere]: Client session seems to have time out. Reauthenticating!") | ||||||
| 			ctx2, cancel2 := context.WithTimeout(ctx, cf.parent.Timeout.Duration) | 			ctx2, cancel2 := context.WithTimeout(ctx, cf.parent.Timeout.Duration) | ||||||
| 			defer cancel2() | 			defer cancel2() | ||||||
| 		if cf.client.Client.SessionManager.Login(ctx2, url.UserPassword(cf.parent.Username, cf.parent.Password)) != nil { | 			if err := cf.client.Client.SessionManager.Login(ctx2, url.UserPassword(cf.parent.Username, cf.parent.Password)); err != nil { | ||||||
|  | 				if !retrying { | ||||||
|  | 					// The client went stale. Probably because someone rebooted vCenter. Clear it to
 | ||||||
|  | 					// force us to create a fresh one. We only get one chance at this. If we fail a second time
 | ||||||
|  | 					// we will simply skip this collection round and hope things have stabilized for the next one.
 | ||||||
|  | 					retrying = true | ||||||
|  | 					cf.client = nil | ||||||
|  | 					continue | ||||||
|  | 				} | ||||||
| 				return nil, fmt.Errorf("Renewing authentication failed: %v", err) | 				return nil, fmt.Errorf("Renewing authentication failed: %v", err) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return cf.client, nil | 		return cf.client, nil | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // NewClient creates a new vSphere client based on the url and setting passed as parameters.
 | // NewClient creates a new vSphere client based on the url and setting passed as parameters.
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue