-
Notifications
You must be signed in to change notification settings - Fork 2.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(ovh): cache refresh and duplicates processing #4932
base: master
Are you sure you want to change the base?
Conversation
Welcome @nmaupu! |
Hi @nmaupu. Thanks for your PR. I'm waiting for a kubernetes-sigs member to verify that this patch is reasonable to test. If it is, they should reply with Once the patch is verified, the new status will be reflected by the I understand the commands that are listed here. Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. |
- Cache was not updated when a change occurred which resulted in a change to be redone at each loop - OVH DNS can have multiple times the exact same entry. Make sure we process all the IDs (instead of picking indefinitely the first one)
0c439cb
to
95d9c3c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @nmaupu !
We were having many issues since 0.15.0 with external-dns crashlooping. I tried a custom build based on your work and it works well.
@alexandrevilain: changing LGTM is restricted to collaborators In response to this:
Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. |
/assign @Raffo |
Ping @mloiseleur @szuecs |
/ok-to-test |
Co-authored-by: Michel Loiseleur <[email protected]>
Co-authored-by: Michel Loiseleur <[email protected]>
/retitle fix(ovh): cache refresh and duplicates processing |
@nmaupu It lgtm, see my last suggestion just to remove some (now) unneeded lines. Btw, If you are interested, you can convert this provider into a webhook one. We have started the process to move the providers out of tree. |
Co-authored-by: Michel Loiseleur <[email protected]>
Co-authored-by: Michel Loiseleur <[email protected]>
Indeed, I will look into it when I get the chance ! |
/retest |
b553f27
to
ae4ebf5
Compare
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: alexandrevilain The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
/retest |
Ping @mloiseleur |
|
||
eg, _ := errgroup.WithContext(ctx) | ||
for zone := range zonesChangeUniques { | ||
zone := zone |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Probably worth to add a comment why this zone := zone
shadowing is required here. Something like
This is necessary because the loop variable zone is reused in each iteration of the loop, and without this line, the goroutines launched by eg.Go would all reference the same zone variable
At first look, I thought is not needed
@@ -215,7 +230,7 @@ func (p *OVHProvider) zonesRecords(ctx context.Context) ([]string, []ovhRecord, | |||
eg.Go(func() error { return p.records(&ctx, &zone, chRecords) }) | |||
} | |||
if err := eg.Wait(); err != nil { | |||
return nil, nil, err | |||
return nil, nil, provider.NewSoftError(err) | |||
} | |||
close(chRecords) | |||
for records := range chRecords { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The line chRecords := make(chan []ovhRecord, len(zones))
creates a slice of a certain lenght. Is it possible that some of the records are nulls? Is it worth to add a null guard?
for records := range chRecords {
if records == null {
continue
}
}
Or it will never happen?
|
||
// The Zone might have multiple records with the same target. In order to avoid applying the action to the | ||
// same OVH record, we remove a record from the list when a match is found. | ||
for i := 0; i < len(newRecords); i++ { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a third nested for-each loop. Matching and removing records worth to consider optimising to reduce complexity and performance.
Something like that, just an idea, not a working code
recordMap := make(map[string]ovhRecord, len(records))
for _, rec := range records {
key := fmt.Sprintf("%s|%s|%s|%s", rec.Zone, rec.SubDomain, rec.FieldType, rec.Target)
recordMap[key] = rec
}
for _, target := range e.Targets {
.....
// Use (datastructure) like the map to find and remove the record
key := fmt.Sprintf("%s|%s|%s|%s", change.Zone, change.SubDomain, change.FieldType, change.Target)
if rec, found := recordMap[key]; found {
change.ID = rec.ID
delete(recordMap, key)
}
}
Description
This PR Fixes all that and make the provider more resilient (all the errors were not soft resulting in the binary to exit).
This also makes #4844 irrelevant as this bug was produced by :
Checklist