From 971277927c028041ee9fac646ac7b25caa8a0f93 Mon Sep 17 00:00:00 2001 From: Minhan Xia Date: Thu, 13 Dec 2018 15:35:34 -0800 Subject: [PATCH] fix a bug where transaction neg syncer will miss neg retry if failure occurs --- pkg/neg/manager.go | 2 +- pkg/neg/syncers/transaction.go | 8 ++++++-- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/pkg/neg/manager.go b/pkg/neg/manager.go index 0b4a6815d8..1ab318a852 100644 --- a/pkg/neg/manager.go +++ b/pkg/neg/manager.go @@ -86,7 +86,7 @@ func (manager *syncerManager) EnsureSyncers(namespace, name string, newPorts neg adds := newPorts.Difference(currentPorts) manager.svcPortMap[key] = newPorts - glog.V(3).Infof("EnsureSyncer %v/%v: removing %v ports, adding %v ports", namespace, name, removes, adds) + glog.V(3).Infof("EnsureSyncer %v/%v: syncing %v ports, removing %v ports, adding %v ports", namespace, name, newPorts, removes, adds) for svcPort, targetPort := range removes { syncer, ok := manager.syncerMap[getSyncerKey(namespace, name, svcPort, targetPort)] diff --git a/pkg/neg/syncers/transaction.go b/pkg/neg/syncers/transaction.go index c4d1871c97..f05c278c64 100644 --- a/pkg/neg/syncers/transaction.go +++ b/pkg/neg/syncers/transaction.go @@ -63,6 +63,8 @@ type transactionSyncer struct { func NewTransactionSyncer(negSyncerKey NegSyncerKey, networkEndpointGroupName string, recorder record.EventRecorder, cloud negtypes.NetworkEndpointGroupCloud, zoneGetter negtypes.ZoneGetter, serviceLister cache.Indexer, endpointLister cache.Indexer) negtypes.NegSyncer { syncer := newSyncer(negSyncerKey, networkEndpointGroupName, serviceLister, recorder) ts := &transactionSyncer{ + NegSyncerKey: negSyncerKey, + negName: networkEndpointGroupName, syncer: syncer, needInit: true, transactions: NewTransactionTable(), @@ -230,8 +232,6 @@ func (s *transactionSyncer) detachNetworkEndpoints(zone string, networkEndpointM // If error occurs or any transaction entry requires reconciliation, it will trigger resync func (s *transactionSyncer) operationInternal(operation transactionOp, zone string, networkEndpointMap map[string]*compute.NetworkEndpoint) { var err error - defer s.commitTransaction(err, networkEndpointMap) - networkEndpoints := []*compute.NetworkEndpoint{} for _, ne := range networkEndpointMap { networkEndpoints = append(networkEndpoints, ne) @@ -250,6 +250,8 @@ func (s *transactionSyncer) operationInternal(operation transactionOp, zone stri s.recordEvent(apiv1.EventTypeWarning, operation.String()+"Failed", fmt.Sprintf("Failed to %s %d network endpoint(s) (NEG %q in zone %q): %v", operation.String(), len(networkEndpointMap), s.negName, zone, err)) } + // WARNING: commitTransaction must be called at last for analyzing the operation result + s.commitTransaction(err, networkEndpointMap) } func (s *transactionSyncer) recordEvent(eventType, reason, eventDesc string) { @@ -274,6 +276,8 @@ func (s *transactionSyncer) commitTransaction(err error, networkEndpointMap map[ needSync := false if err != nil { + // Trigger NEG initialization if error occurs + // This is to prevent if the NEG object is deleted or misconfigured by user s.needInit = true needRetry = true }