kubernetes/plugin/pkg/scheduler
Kubernetes Submit Queue 2faf7ff2bc Merge pull request #36238 from resouer/eclass-2-dev
Automatic merge from submit-queue (batch tested with PRs 48043, 48200, 49139, 36238, 49130)

Implement equivalence cache by caching and re-using predicate result

The last part of #30844, I opened a new PR instead of overwrite the old one because we changed some basic assumption by allowing invalidating equivalence cache item by individual predicate.

The idea of this PR is based on discussion in https://github.com/kubernetes/kubernetes/issues/32024

- [x]  Pods belong to same controllerRef considered to be equivalent
- [x] ` podFitsOnNode` will use cached predicate result if it's available
- [x] Equivalence cache will be updated when if a fresh new predicate is done
- [x] `factory.go` will invalid specific predicate cache(s) based on the object change
- [x] Since `schedule` and `bind` are async, we need to optimistically invalid affected cache(s) before `bind`
- [x] Fully unit test of affected files
- [x] e2e test to verify cache update/invalid workflow
- [x] performance test results

- [x] Some nits fixes related but expected to result in `needs-rebase` so they are split to: #36060 #35968 #37512

cc @wojtek-t @davidopp
2017-07-19 01:57:32 -07:00
..
algorithm Remove affinity annotations leftover 2017-07-18 19:42:52 +08:00
algorithmprovider Update factory.go informers to update equivalence cache 2017-07-18 23:55:01 +08:00
api Update generated code 2017-07-18 09:28:49 +02:00
core Update factory.go informers to update equivalence cache 2017-07-18 23:55:01 +08:00
factory Update generated bazel 2017-07-18 23:58:32 +08:00
metrics autogenerated 2017-04-14 10:40:57 -07:00
schedulercache Merge pull request #46926 from k82cn/k8s_46924 2017-07-04 06:56:22 -07:00
testing run hack/update-all 2017-06-22 11:31:03 -07:00
util Merge pull request #47309 from xiang90/util 2017-07-16 20:00:54 -07:00
BUILD Scripted migration from clientset_generated to client-go. 2017-07-17 15:05:37 -07:00
OWNERS Updated OWNERS_ALIASES for scheduler, and added scheduler integration test owners. 2017-07-01 09:28:52 +08:00
scheduler.go Scripted migration from clientset_generated to client-go. 2017-07-17 15:05:37 -07:00
scheduler_test.go use v1.ResourcePods instead of hard coding 'pods' 2017-07-13 18:20:47 +08:00
testutil.go Scripted migration from clientset_generated to client-go. 2017-07-17 15:05:37 -07:00