Skip to content
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

Avoid reloads when route configuration hasn't changed #12242

Merged
merged 3 commits into from
Dec 21, 2016

Conversation

marun
Copy link
Contributor

@marun marun commented Dec 13, 2016

Previously, 'Added' and 'Modified' route events would always result in a router state change that required a reload. This change ensures that the router computes the configuration of the route provided by an event and only makes a reload-requiring state change if the new configuration differs from the old. Along with the changes from #12199, routers should no longer have to reload unless route and endpoint configuration changes.

Please review only c4636aa and 93173fe. The other commits are from #12199 and a necessary precursor to this work, but that PR may be close to merging and I didn't want to delay things by adding more code at the last minute.

cc: @openshift/networking @smarterclayton

@marun
Copy link
Contributor Author

marun commented Dec 13, 2016

[test]

@marun marun force-pushed the router-reload-only-when-changed branch 3 times, most recently from 543f3a5 to 077863b Compare December 13, 2016 17:21
@smarterclayton
Copy link
Contributor

smarterclayton commented Dec 13, 2016 via email

@marun marun force-pushed the router-reload-only-when-changed branch from 077863b to c4636aa Compare December 13, 2016 19:03
Copy link
Contributor

@knobunc knobunc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM. Thanks Maru!

@knobunc
Copy link
Contributor

knobunc commented Dec 13, 2016

@smarterclayton I want to get this into a 3.4 maintenance release too.

@marun
Copy link
Contributor Author

marun commented Dec 13, 2016

flake #12184

re-[test]


// routeKeys returns the internal router keys to use for the given Route.
// A route can have several services that it can point to, now
func routeKeys(route *routeapi.Route) ([]string, []int32) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There's already a routeKey method in this file - could be confusing *Key vs *Keys but its minor.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, I've added another commit that renames and refactors this method. PTAL.

Copy link
Contributor

@ramr ramr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@ramr
Copy link
Contributor

ramr commented Dec 13, 2016

New code w/ getServiceUnits lgtm - thx

@marun
Copy link
Contributor Author

marun commented Dec 13, 2016

@ramr Thank you for your diligence!

@rajatchopra Would appreciate your eyes when you get a chance to make sure I have maintained your intent around a/b testing.

Copy link
Contributor

@rajatchopra rajatchopra left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Amazing set of optimizations. LGTM

@marun
Copy link
Contributor Author

marun commented Dec 19, 2016

Adding some logging cleanup. %v outputs garbage for a route.

Copy link
Contributor

@knobunc knobunc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Logging changes LGTM. Thanks for the cleanup.

@knobunc
Copy link
Contributor

knobunc commented Dec 19, 2016

[test] flaked on #11016 (the router took longer than 1 minute to pull images and start them)

@marun
Copy link
Contributor Author

marun commented Dec 19, 2016

flake #10773

re-merge?

@marun
Copy link
Contributor Author

marun commented Dec 19, 2016

re-[test]

1 similar comment
@marun
Copy link
Contributor Author

marun commented Dec 20, 2016

re-[test]

@marun marun force-pushed the router-reload-only-when-changed branch from faba567 to de79651 Compare December 20, 2016 05:44
@marun
Copy link
Contributor Author

marun commented Dec 20, 2016

Rebased

Previously, 'Added' and 'Modified' route events would always result in
a router state change that required a reload.  This change ensures
that the router computes the configuration of the route provided by an
event and only makes a reload-requiring state change if the new
configuration differs from the old.
Minor refactor and rename of the routeKeys (now getServiceUnits)
utility function.
@openshift-bot
Copy link
Contributor

Evaluated for origin test up to de79651

@openshift-bot
Copy link
Contributor

continuous-integration/openshift-jenkins/test SUCCESS (https://ci.openshift.redhat.com/jenkins/job/test_pr_origin/12532/) (Base Commit: 3c68360)

@knobunc
Copy link
Contributor

knobunc commented Dec 20, 2016

[merge]

@marun
Copy link
Contributor Author

marun commented Dec 21, 2016

flake #11004 #11662

re-[merge]

@openshift-bot
Copy link
Contributor

Evaluated for origin merge up to de79651

@openshift-bot
Copy link
Contributor

openshift-bot commented Dec 21, 2016

continuous-integration/openshift-jenkins/merge SUCCESS (https://ci.openshift.redhat.com/jenkins/job/test_pr_origin/12562/) (Base Commit: 42ad22e) (Image: devenv-rhel7_5578)

@openshift-bot openshift-bot merged commit ec2d33a into openshift:master Dec 21, 2016
@marun marun deleted the router-reload-only-when-changed branch December 21, 2016 04:51
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants