Merge pull request #33425 from ZTE-PaaS/zhangke-patch-051
Automatic merge from submit-queue Use abstract cache.NewListWatchFromClient to make the code clean
This commit is contained in:
@@ -68,7 +68,6 @@ import (
|
|||||||
"k8s.io/kubernetes/pkg/kubelet/util/sliceutils"
|
"k8s.io/kubernetes/pkg/kubelet/util/sliceutils"
|
||||||
"k8s.io/kubernetes/pkg/kubelet/volumemanager"
|
"k8s.io/kubernetes/pkg/kubelet/volumemanager"
|
||||||
"k8s.io/kubernetes/pkg/labels"
|
"k8s.io/kubernetes/pkg/labels"
|
||||||
"k8s.io/kubernetes/pkg/runtime"
|
|
||||||
"k8s.io/kubernetes/pkg/security/apparmor"
|
"k8s.io/kubernetes/pkg/security/apparmor"
|
||||||
"k8s.io/kubernetes/pkg/types"
|
"k8s.io/kubernetes/pkg/types"
|
||||||
"k8s.io/kubernetes/pkg/util/bandwidth"
|
"k8s.io/kubernetes/pkg/util/bandwidth"
|
||||||
@@ -88,7 +87,6 @@ import (
|
|||||||
"k8s.io/kubernetes/pkg/util/sets"
|
"k8s.io/kubernetes/pkg/util/sets"
|
||||||
"k8s.io/kubernetes/pkg/util/wait"
|
"k8s.io/kubernetes/pkg/util/wait"
|
||||||
"k8s.io/kubernetes/pkg/volume"
|
"k8s.io/kubernetes/pkg/volume"
|
||||||
"k8s.io/kubernetes/pkg/watch"
|
|
||||||
"k8s.io/kubernetes/plugin/pkg/scheduler/algorithm/predicates"
|
"k8s.io/kubernetes/plugin/pkg/scheduler/algorithm/predicates"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -359,36 +357,16 @@ func NewMainKubelet(kubeCfg *componentconfig.KubeletConfiguration, kubeDeps *Kub
|
|||||||
|
|
||||||
serviceStore := cache.NewIndexer(cache.MetaNamespaceKeyFunc, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc})
|
serviceStore := cache.NewIndexer(cache.MetaNamespaceKeyFunc, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc})
|
||||||
if kubeClient != nil {
|
if kubeClient != nil {
|
||||||
// TODO: cache.NewListWatchFromClient is limited as it takes a client implementation rather
|
serviceLW := cache.NewListWatchFromClient(kubeClient.(*clientset.Clientset).CoreClient, "services", api.NamespaceAll, fields.Everything())
|
||||||
// than an interface. There is no way to construct a list+watcher using resource name.
|
cache.NewReflector(serviceLW, &api.Service{}, serviceStore, 0).Run()
|
||||||
listWatch := &cache.ListWatch{
|
|
||||||
ListFunc: func(options api.ListOptions) (runtime.Object, error) {
|
|
||||||
return kubeClient.Core().Services(api.NamespaceAll).List(options)
|
|
||||||
},
|
|
||||||
WatchFunc: func(options api.ListOptions) (watch.Interface, error) {
|
|
||||||
return kubeClient.Core().Services(api.NamespaceAll).Watch(options)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
cache.NewReflector(listWatch, &api.Service{}, serviceStore, 0).Run()
|
|
||||||
}
|
}
|
||||||
serviceLister := &cache.StoreToServiceLister{Indexer: serviceStore}
|
serviceLister := &cache.StoreToServiceLister{Indexer: serviceStore}
|
||||||
|
|
||||||
nodeStore := cache.NewStore(cache.MetaNamespaceKeyFunc)
|
nodeStore := cache.NewStore(cache.MetaNamespaceKeyFunc)
|
||||||
if kubeClient != nil {
|
if kubeClient != nil {
|
||||||
// TODO: cache.NewListWatchFromClient is limited as it takes a client implementation rather
|
|
||||||
// than an interface. There is no way to construct a list+watcher using resource name.
|
|
||||||
fieldSelector := fields.Set{api.ObjectNameField: string(nodeName)}.AsSelector()
|
fieldSelector := fields.Set{api.ObjectNameField: string(nodeName)}.AsSelector()
|
||||||
listWatch := &cache.ListWatch{
|
nodeLW := cache.NewListWatchFromClient(kubeClient.(*clientset.Clientset).CoreClient, "nodes", api.NamespaceAll, fieldSelector)
|
||||||
ListFunc: func(options api.ListOptions) (runtime.Object, error) {
|
cache.NewReflector(nodeLW, &api.Node{}, nodeStore, 0).Run()
|
||||||
options.FieldSelector = fieldSelector
|
|
||||||
return kubeClient.Core().Nodes().List(options)
|
|
||||||
},
|
|
||||||
WatchFunc: func(options api.ListOptions) (watch.Interface, error) {
|
|
||||||
options.FieldSelector = fieldSelector
|
|
||||||
return kubeClient.Core().Nodes().Watch(options)
|
|
||||||
},
|
|
||||||
}
|
|
||||||
cache.NewReflector(listWatch, &api.Node{}, nodeStore, 0).Run()
|
|
||||||
}
|
}
|
||||||
nodeLister := &cache.StoreToNodeLister{Store: nodeStore}
|
nodeLister := &cache.StoreToNodeLister{Store: nodeStore}
|
||||||
nodeInfo := &predicates.CachedNodeInfo{StoreToNodeLister: nodeLister}
|
nodeInfo := &predicates.CachedNodeInfo{StoreToNodeLister: nodeLister}
|
||||||
|
Reference in New Issue
Block a user