Add information about ports opened by Kubelet to API
This commit is contained in:
		| @@ -11770,9 +11770,13 @@ | |||||||
|       }, |       }, | ||||||
|       "description": "List of addresses reachable to the node. Queried from cloud provider, if available. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses" |       "description": "List of addresses reachable to the node. Queried from cloud provider, if available. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses" | ||||||
|      }, |      }, | ||||||
|  |      "daemonEndpoints": { | ||||||
|  |       "$ref": "v1.NodeDaemonEndpoints", | ||||||
|  |       "description": "Endpoints of daemons running on the Node." | ||||||
|  |      }, | ||||||
|      "nodeInfo": { |      "nodeInfo": { | ||||||
|       "$ref": "v1.NodeSystemInfo", |       "$ref": "v1.NodeSystemInfo", | ||||||
|       "description": "NodeSystemInfo is a set of ids/uuids to uniquely identify the node. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info" |       "description": "Set of ids/uuids to uniquely identify the node. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info" | ||||||
|      } |      } | ||||||
|     } |     } | ||||||
|    }, |    }, | ||||||
| @@ -11828,6 +11832,30 @@ | |||||||
|      } |      } | ||||||
|     } |     } | ||||||
|    }, |    }, | ||||||
|  |    "v1.NodeDaemonEndpoints": { | ||||||
|  |     "id": "v1.NodeDaemonEndpoints", | ||||||
|  |     "description": "NodeDaemonEndpoints lists ports opened by daemons running on the Node.", | ||||||
|  |     "properties": { | ||||||
|  |      "kubeletEndpoint": { | ||||||
|  |       "$ref": "v1.DaemonEndpoint", | ||||||
|  |       "description": "Endpoint on which Kubelet is listening." | ||||||
|  |      } | ||||||
|  |     } | ||||||
|  |    }, | ||||||
|  |    "v1.DaemonEndpoint": { | ||||||
|  |     "id": "v1.DaemonEndpoint", | ||||||
|  |     "description": "DaemonEndpoint contains information about a single Daemon endpoint.", | ||||||
|  |     "required": [ | ||||||
|  |      "Port" | ||||||
|  |     ], | ||||||
|  |     "properties": { | ||||||
|  |      "Port": { | ||||||
|  |       "type": "integer", | ||||||
|  |       "format": "int32", | ||||||
|  |       "description": "Port number of the given endpoint." | ||||||
|  |      } | ||||||
|  |     } | ||||||
|  |    }, | ||||||
|    "v1.NodeSystemInfo": { |    "v1.NodeSystemInfo": { | ||||||
|     "id": "v1.NodeSystemInfo", |     "id": "v1.NodeSystemInfo", | ||||||
|     "description": "NodeSystemInfo is a set of ids/uuids to uniquely identify the node.", |     "description": "NodeSystemInfo is a set of ids/uuids to uniquely identify the node.", | ||||||
| @@ -11844,35 +11872,35 @@ | |||||||
|     "properties": { |     "properties": { | ||||||
|      "machineID": { |      "machineID": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "MachineID is the machine-id reported by the node." |       "description": "Machine ID reported by the node." | ||||||
|      }, |      }, | ||||||
|      "systemUUID": { |      "systemUUID": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "SystemUUID is the system-uuid reported by the node." |       "description": "System UUID reported by the node." | ||||||
|      }, |      }, | ||||||
|      "bootID": { |      "bootID": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "BootID is the boot-id reported by the node." |       "description": "Boot ID reported by the node." | ||||||
|      }, |      }, | ||||||
|      "kernelVersion": { |      "kernelVersion": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "Kernel version reported by the node from 'uname -r' (e.g. 3.16.0-0.bpo.4-amd64)" |       "description": "Kernel Version reported by the node from 'uname -r' (e.g. 3.16.0-0.bpo.4-amd64)." | ||||||
|      }, |      }, | ||||||
|      "osImage": { |      "osImage": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "OS image used reported by the node from /etc/os-release (e.g. Debian GNU/Linux 7 (wheezy))" |       "description": "OS Image reported by the node from /etc/os-release (e.g. Debian GNU/Linux 7 (wheezy))." | ||||||
|      }, |      }, | ||||||
|      "containerRuntimeVersion": { |      "containerRuntimeVersion": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "Container runtime version reported by the node through runtime remote API (e.g. docker://1.5.0)" |       "description": "ContainerRuntime Version reported by the node through runtime remote API (e.g. docker://1.5.0)." | ||||||
|      }, |      }, | ||||||
|      "kubeletVersion": { |      "kubeletVersion": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "Kubelet version reported by the node." |       "description": "Kubelet Version reported by the node." | ||||||
|      }, |      }, | ||||||
|      "kubeProxyVersion": { |      "kubeProxyVersion": { | ||||||
|       "type": "string", |       "type": "string", | ||||||
|       "description": "Kube-proxy version reported by the node." |       "description": "KubeProxy Version reported by the node." | ||||||
|      } |      } | ||||||
|     } |     } | ||||||
|    }, |    }, | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ type KubeletServer struct { | |||||||
| 	AllowPrivileged                bool | 	AllowPrivileged                bool | ||||||
| 	APIServerList                  []string | 	APIServerList                  []string | ||||||
| 	AuthPath                       util.StringFlag // Deprecated -- use KubeConfig instead | 	AuthPath                       util.StringFlag // Deprecated -- use KubeConfig instead | ||||||
| 	CadvisorPort                   uint | 	CAdvisorPort                   uint | ||||||
| 	CertDirectory                  string | 	CertDirectory                  string | ||||||
| 	CgroupRoot                     string | 	CgroupRoot                     string | ||||||
| 	CloudConfigFile                string | 	CloudConfigFile                string | ||||||
| @@ -156,7 +156,7 @@ func NewKubeletServer() *KubeletServer { | |||||||
| 	return &KubeletServer{ | 	return &KubeletServer{ | ||||||
| 		Address:                     net.ParseIP("0.0.0.0"), | 		Address:                     net.ParseIP("0.0.0.0"), | ||||||
| 		AuthPath:                    util.NewStringFlag("/var/lib/kubelet/kubernetes_auth"), // deprecated | 		AuthPath:                    util.NewStringFlag("/var/lib/kubelet/kubernetes_auth"), // deprecated | ||||||
| 		CadvisorPort:                4194, | 		CAdvisorPort:                4194, | ||||||
| 		CertDirectory:               "/var/run/kubernetes", | 		CertDirectory:               "/var/run/kubernetes", | ||||||
| 		CgroupRoot:                  "", | 		CgroupRoot:                  "", | ||||||
| 		ConfigureCBR0:               false, | 		ConfigureCBR0:               false, | ||||||
| @@ -234,7 +234,7 @@ func (s *KubeletServer) AddFlags(fs *pflag.FlagSet) { | |||||||
| 	fs.Var(&s.AuthPath, "auth-path", "Path to .kubernetes_auth file, specifying how to authenticate to API server.") | 	fs.Var(&s.AuthPath, "auth-path", "Path to .kubernetes_auth file, specifying how to authenticate to API server.") | ||||||
| 	fs.MarkDeprecated("auth-path", "will be removed in a future version") | 	fs.MarkDeprecated("auth-path", "will be removed in a future version") | ||||||
| 	fs.Var(&s.KubeConfig, "kubeconfig", "Path to a kubeconfig file, specifying how to authenticate to API server (the master location is set by the api-servers flag).") | 	fs.Var(&s.KubeConfig, "kubeconfig", "Path to a kubeconfig file, specifying how to authenticate to API server (the master location is set by the api-servers flag).") | ||||||
| 	fs.UintVar(&s.CadvisorPort, "cadvisor-port", s.CadvisorPort, "The port of the localhost cAdvisor endpoint") | 	fs.UintVar(&s.CAdvisorPort, "cadvisor-port", s.CAdvisorPort, "The port of the localhost cAdvisor endpoint") | ||||||
| 	fs.IntVar(&s.HealthzPort, "healthz-port", s.HealthzPort, "The port of the localhost healthz endpoint") | 	fs.IntVar(&s.HealthzPort, "healthz-port", s.HealthzPort, "The port of the localhost healthz endpoint") | ||||||
| 	fs.IPVar(&s.HealthzBindAddress, "healthz-bind-address", s.HealthzBindAddress, "The IP address for the healthz server to serve on, defaulting to 127.0.0.1 (set to 0.0.0.0 for all interfaces)") | 	fs.IPVar(&s.HealthzBindAddress, "healthz-bind-address", s.HealthzBindAddress, "The IP address for the healthz server to serve on, defaulting to 127.0.0.1 (set to 0.0.0.0 for all interfaces)") | ||||||
| 	fs.IntVar(&s.OOMScoreAdj, "oom-score-adj", s.OOMScoreAdj, "The oom-score-adj value for kubelet process. Values must be within the range [-1000, 1000]") | 	fs.IntVar(&s.OOMScoreAdj, "oom-score-adj", s.OOMScoreAdj, "The oom-score-adj value for kubelet process. Values must be within the range [-1000, 1000]") | ||||||
| @@ -322,7 +322,7 @@ func (s *KubeletServer) KubeletConfig() (*KubeletConfig, error) { | |||||||
| 	return &KubeletConfig{ | 	return &KubeletConfig{ | ||||||
| 		Address:                   s.Address, | 		Address:                   s.Address, | ||||||
| 		AllowPrivileged:           s.AllowPrivileged, | 		AllowPrivileged:           s.AllowPrivileged, | ||||||
| 		CadvisorInterface:         nil, // launches background processes, not set here | 		CAdvisorInterface:         nil, // launches background processes, not set here | ||||||
| 		CgroupRoot:                s.CgroupRoot, | 		CgroupRoot:                s.CgroupRoot, | ||||||
| 		Cloud:                     nil, // cloud provider might start background processes | 		Cloud:                     nil, // cloud provider might start background processes | ||||||
| 		ClusterDNS:                s.ClusterDNS, | 		ClusterDNS:                s.ClusterDNS, | ||||||
| @@ -407,12 +407,12 @@ func (s *KubeletServer) Run(kcfg *KubeletConfig) error { | |||||||
| 		kcfg.Cloud = cloud | 		kcfg.Cloud = cloud | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if kcfg.CadvisorInterface == nil { | 	if kcfg.CAdvisorInterface == nil { | ||||||
| 		ca, err := cadvisor.New(s.CadvisorPort) | 		ca, err := cadvisor.New(s.CAdvisorPort) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
| 		kcfg.CadvisorInterface = ca | 		kcfg.CAdvisorInterface = ca | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	util.ReallyCrash = s.ReallyCrashForTesting | 	util.ReallyCrash = s.ReallyCrashForTesting | ||||||
| @@ -585,7 +585,7 @@ func SimpleKubelet(client *client.Client, | |||||||
| 	} | 	} | ||||||
| 	kcfg := KubeletConfig{ | 	kcfg := KubeletConfig{ | ||||||
| 		Address:                   net.ParseIP(address), | 		Address:                   net.ParseIP(address), | ||||||
| 		CadvisorInterface:         cadvisorInterface, | 		CAdvisorInterface:         cadvisorInterface, | ||||||
| 		CgroupRoot:                "", | 		CgroupRoot:                "", | ||||||
| 		Cloud:                     cloud, | 		Cloud:                     cloud, | ||||||
| 		ConfigFile:                configFilePath, | 		ConfigFile:                configFilePath, | ||||||
| @@ -745,7 +745,7 @@ func makePodSourceConfig(kc *KubeletConfig) *config.PodConfig { | |||||||
| type KubeletConfig struct { | type KubeletConfig struct { | ||||||
| 	Address                        net.IP | 	Address                        net.IP | ||||||
| 	AllowPrivileged                bool | 	AllowPrivileged                bool | ||||||
| 	CadvisorInterface              cadvisor.Interface | 	CAdvisorInterface              cadvisor.Interface | ||||||
| 	CgroupRoot                     string | 	CgroupRoot                     string | ||||||
| 	Cloud                          cloudprovider.Interface | 	Cloud                          cloudprovider.Interface | ||||||
| 	ClusterDNS                     net.IP | 	ClusterDNS                     net.IP | ||||||
| @@ -821,6 +821,10 @@ func createAndInitKubelet(kc *KubeletConfig) (k KubeletBootstrap, pc *config.Pod | |||||||
| 		MaxContainers:      kc.MaxContainerCount, | 		MaxContainers:      kc.MaxContainerCount, | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	daemonEndpoints := &api.NodeDaemonEndpoints{ | ||||||
|  | 		KubeletEndpoint: api.DaemonEndpoint{Port: int(kc.Port)}, | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	pc = makePodSourceConfig(kc) | 	pc = makePodSourceConfig(kc) | ||||||
| 	k, err = kubelet.NewMainKubelet( | 	k, err = kubelet.NewMainKubelet( | ||||||
| 		kc.Hostname, | 		kc.Hostname, | ||||||
| @@ -846,7 +850,7 @@ func createAndInitKubelet(kc *KubeletConfig) (k KubeletBootstrap, pc *config.Pod | |||||||
| 		kc.NetworkPluginName, | 		kc.NetworkPluginName, | ||||||
| 		kc.StreamingConnectionIdleTimeout, | 		kc.StreamingConnectionIdleTimeout, | ||||||
| 		kc.Recorder, | 		kc.Recorder, | ||||||
| 		kc.CadvisorInterface, | 		kc.CAdvisorInterface, | ||||||
| 		kc.ImageGCPolicy, | 		kc.ImageGCPolicy, | ||||||
| 		kc.DiskSpacePolicy, | 		kc.DiskSpacePolicy, | ||||||
| 		kc.Cloud, | 		kc.Cloud, | ||||||
| @@ -865,7 +869,8 @@ func createAndInitKubelet(kc *KubeletConfig) (k KubeletBootstrap, pc *config.Pod | |||||||
| 		kc.MaxPods, | 		kc.MaxPods, | ||||||
| 		kc.DockerExecHandler, | 		kc.DockerExecHandler, | ||||||
| 		kc.ResolverConfig, | 		kc.ResolverConfig, | ||||||
| 		kc.CPUCFSQuota) | 		kc.CPUCFSQuota, | ||||||
|  | 		daemonEndpoints) | ||||||
|  |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, err | 		return nil, nil, err | ||||||
|   | |||||||
| @@ -132,7 +132,7 @@ func (s *KubeletExecutorServer) Run(hks hyperkube.Interface, _ []string) error { | |||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	cadvisorInterface, err := cadvisor.New(s.CadvisorPort) | 	cAdvisorInterface, err := cadvisor.New(s.CAdvisorPort) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -203,7 +203,7 @@ func (s *KubeletExecutorServer) Run(hks hyperkube.Interface, _ []string) error { | |||||||
| 		Runonce:                        s.RunOnce, | 		Runonce:                        s.RunOnce, | ||||||
| 		Port:                           s.Port, | 		Port:                           s.Port, | ||||||
| 		ReadOnlyPort:                   s.ReadOnlyPort, | 		ReadOnlyPort:                   s.ReadOnlyPort, | ||||||
| 		CadvisorInterface:              cadvisorInterface, | 		CAdvisorInterface:              cAdvisorInterface, | ||||||
| 		EnableServer:                   s.EnableServer, | 		EnableServer:                   s.EnableServer, | ||||||
| 		EnableDebuggingHandlers:        s.EnableDebuggingHandlers, | 		EnableDebuggingHandlers:        s.EnableDebuggingHandlers, | ||||||
| 		DockerClient:                   dockertools.ConnectToDockerOrDie(s.DockerEndpoint), | 		DockerClient:                   dockertools.ConnectToDockerOrDie(s.DockerEndpoint), | ||||||
| @@ -315,7 +315,7 @@ func (ks *KubeletExecutorServer) createAndInitKubelet( | |||||||
| 		kc.NetworkPluginName, | 		kc.NetworkPluginName, | ||||||
| 		kc.StreamingConnectionIdleTimeout, | 		kc.StreamingConnectionIdleTimeout, | ||||||
| 		kc.Recorder, | 		kc.Recorder, | ||||||
| 		kc.CadvisorInterface, | 		kc.CAdvisorInterface, | ||||||
| 		kc.ImageGCPolicy, | 		kc.ImageGCPolicy, | ||||||
| 		kc.DiskSpacePolicy, | 		kc.DiskSpacePolicy, | ||||||
| 		kc.Cloud, | 		kc.Cloud, | ||||||
| @@ -335,6 +335,9 @@ func (ks *KubeletExecutorServer) createAndInitKubelet( | |||||||
| 		kc.DockerExecHandler, | 		kc.DockerExecHandler, | ||||||
| 		kc.ResolverConfig, | 		kc.ResolverConfig, | ||||||
| 		kc.CPUCFSQuota, | 		kc.CPUCFSQuota, | ||||||
|  | 		&api.NodeDaemonEndpoints{ | ||||||
|  | 			KubeletEndpoint: api.DaemonEndpoint{Port: int(kc.Port)}, | ||||||
|  | 		}, | ||||||
| 	) | 	) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, err | 		return nil, nil, err | ||||||
|   | |||||||
| @@ -322,6 +322,11 @@ func deepCopy_api_ContainerStatus(in ContainerStatus, out *ContainerStatus, c *c | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func deepCopy_api_DaemonEndpoint(in DaemonEndpoint, out *DaemonEndpoint, c *conversion.Cloner) error { | ||||||
|  | 	out.Port = in.Port | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func deepCopy_api_DeleteOptions(in DeleteOptions, out *DeleteOptions, c *conversion.Cloner) error { | func deepCopy_api_DeleteOptions(in DeleteOptions, out *DeleteOptions, c *conversion.Cloner) error { | ||||||
| 	if err := deepCopy_api_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | 	if err := deepCopy_api_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -914,6 +919,13 @@ func deepCopy_api_NodeCondition(in NodeCondition, out *NodeCondition, c *convers | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func deepCopy_api_NodeDaemonEndpoints(in NodeDaemonEndpoints, out *NodeDaemonEndpoints, c *conversion.Cloner) error { | ||||||
|  | 	if err := deepCopy_api_DaemonEndpoint(in.KubeletEndpoint, &out.KubeletEndpoint, c); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func deepCopy_api_NodeList(in NodeList, out *NodeList, c *conversion.Cloner) error { | func deepCopy_api_NodeList(in NodeList, out *NodeList, c *conversion.Cloner) error { | ||||||
| 	if err := deepCopy_api_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | 	if err := deepCopy_api_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -976,6 +988,9 @@ func deepCopy_api_NodeStatus(in NodeStatus, out *NodeStatus, c *conversion.Clone | |||||||
| 	} else { | 	} else { | ||||||
| 		out.Addresses = nil | 		out.Addresses = nil | ||||||
| 	} | 	} | ||||||
|  | 	if err := deepCopy_api_NodeDaemonEndpoints(in.DaemonEndpoints, &out.DaemonEndpoints, c); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
| 	if err := deepCopy_api_NodeSystemInfo(in.NodeInfo, &out.NodeInfo, c); err != nil { | 	if err := deepCopy_api_NodeSystemInfo(in.NodeInfo, &out.NodeInfo, c); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -2238,6 +2253,7 @@ func init() { | |||||||
| 		deepCopy_api_ContainerStateTerminated, | 		deepCopy_api_ContainerStateTerminated, | ||||||
| 		deepCopy_api_ContainerStateWaiting, | 		deepCopy_api_ContainerStateWaiting, | ||||||
| 		deepCopy_api_ContainerStatus, | 		deepCopy_api_ContainerStatus, | ||||||
|  | 		deepCopy_api_DaemonEndpoint, | ||||||
| 		deepCopy_api_DeleteOptions, | 		deepCopy_api_DeleteOptions, | ||||||
| 		deepCopy_api_DownwardAPIVolumeFile, | 		deepCopy_api_DownwardAPIVolumeFile, | ||||||
| 		deepCopy_api_DownwardAPIVolumeSource, | 		deepCopy_api_DownwardAPIVolumeSource, | ||||||
| @@ -2279,6 +2295,7 @@ func init() { | |||||||
| 		deepCopy_api_Node, | 		deepCopy_api_Node, | ||||||
| 		deepCopy_api_NodeAddress, | 		deepCopy_api_NodeAddress, | ||||||
| 		deepCopy_api_NodeCondition, | 		deepCopy_api_NodeCondition, | ||||||
|  | 		deepCopy_api_NodeDaemonEndpoints, | ||||||
| 		deepCopy_api_NodeList, | 		deepCopy_api_NodeList, | ||||||
| 		deepCopy_api_NodeSpec, | 		deepCopy_api_NodeSpec, | ||||||
| 		deepCopy_api_NodeStatus, | 		deepCopy_api_NodeStatus, | ||||||
|   | |||||||
| @@ -1366,23 +1366,35 @@ type NodeSpec struct { | |||||||
| 	Unschedulable bool `json:"unschedulable,omitempty"` | 	Unschedulable bool `json:"unschedulable,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // DaemonEndpoint contains information about a single Daemon endpoint. | ||||||
|  | type DaemonEndpoint struct { | ||||||
|  | 	// Port number of the given endpoint. | ||||||
|  | 	Port int `json:port` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // NodeDaemonEndpoints lists ports opened by daemons running on the Node. | ||||||
|  | type NodeDaemonEndpoints struct { | ||||||
|  | 	// Endpoint on which Kubelet is listening. | ||||||
|  | 	KubeletEndpoint DaemonEndpoint `json:"kubeletEndpoint,omitempty"` | ||||||
|  | } | ||||||
|  |  | ||||||
| // NodeSystemInfo is a set of ids/uuids to uniquely identify the node. | // NodeSystemInfo is a set of ids/uuids to uniquely identify the node. | ||||||
| type NodeSystemInfo struct { | type NodeSystemInfo struct { | ||||||
| 	// MachineID is the machine-id reported by the node | 	// Machine ID reported by the node. | ||||||
| 	MachineID string `json:"machineID"` | 	MachineID string `json:"machineID"` | ||||||
| 	// SystemUUID is the system-uuid reported by the node | 	// System UUID reported by the node. | ||||||
| 	SystemUUID string `json:"systemUUID"` | 	SystemUUID string `json:"systemUUID"` | ||||||
| 	// BootID is the boot-id reported by the node | 	// Boot ID reported by the node. | ||||||
| 	BootID string `json:"bootID"` | 	BootID string `json:"bootID"` | ||||||
| 	// Kernel version reported by the node | 	// Kernel Version reported by the node. | ||||||
| 	KernelVersion string `json:"kernelVersion"` | 	KernelVersion string `json:"kernelVersion"` | ||||||
| 	// OS image used reported by the node | 	// OS Image reported by the node. | ||||||
| 	OsImage string `json:"osImage"` | 	OsImage string `json:"osImage"` | ||||||
| 	// Container runtime version reported by the node | 	// ContainerRuntime Version reported by the node. | ||||||
| 	ContainerRuntimeVersion string `json:"containerRuntimeVersion"` | 	ContainerRuntimeVersion string `json:"containerRuntimeVersion"` | ||||||
| 	// Kubelet version reported by the node | 	// Kubelet Version reported by the node. | ||||||
| 	KubeletVersion string `json:"kubeletVersion"` | 	KubeletVersion string `json:"kubeletVersion"` | ||||||
| 	// Kube-proxy version reported by the node | 	// KubeProxy Version reported by the node. | ||||||
| 	KubeProxyVersion string `json:"kubeProxyVersion"` | 	KubeProxyVersion string `json:"kubeProxyVersion"` | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1396,7 +1408,9 @@ type NodeStatus struct { | |||||||
| 	Conditions []NodeCondition `json:"conditions,omitempty"` | 	Conditions []NodeCondition `json:"conditions,omitempty"` | ||||||
| 	// Queried from cloud provider, if available. | 	// Queried from cloud provider, if available. | ||||||
| 	Addresses []NodeAddress `json:"addresses,omitempty"` | 	Addresses []NodeAddress `json:"addresses,omitempty"` | ||||||
| 	// NodeSystemInfo is a set of ids/uuids to uniquely identify the node | 	// Endpoints of daemons running on the Node. | ||||||
|  | 	DaemonEndpoints NodeDaemonEndpoints `json:"daemonEndpoints,omitempty"` | ||||||
|  | 	// Set of ids/uuids to uniquely identify the node. | ||||||
| 	NodeInfo NodeSystemInfo `json:"nodeInfo,omitempty"` | 	NodeInfo NodeSystemInfo `json:"nodeInfo,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -363,6 +363,14 @@ func convert_api_ContainerStatus_To_v1_ContainerStatus(in *api.ContainerStatus, | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func convert_api_DaemonEndpoint_To_v1_DaemonEndpoint(in *api.DaemonEndpoint, out *DaemonEndpoint, s conversion.Scope) error { | ||||||
|  | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
|  | 		defaulting.(func(*api.DaemonEndpoint))(in) | ||||||
|  | 	} | ||||||
|  | 	out.Port = in.Port | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func convert_api_DeleteOptions_To_v1_DeleteOptions(in *api.DeleteOptions, out *DeleteOptions, s conversion.Scope) error { | func convert_api_DeleteOptions_To_v1_DeleteOptions(in *api.DeleteOptions, out *DeleteOptions, s conversion.Scope) error { | ||||||
| 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
| 		defaulting.(func(*api.DeleteOptions))(in) | 		defaulting.(func(*api.DeleteOptions))(in) | ||||||
| @@ -1059,6 +1067,16 @@ func convert_api_NodeCondition_To_v1_NodeCondition(in *api.NodeCondition, out *N | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func convert_api_NodeDaemonEndpoints_To_v1_NodeDaemonEndpoints(in *api.NodeDaemonEndpoints, out *NodeDaemonEndpoints, s conversion.Scope) error { | ||||||
|  | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
|  | 		defaulting.(func(*api.NodeDaemonEndpoints))(in) | ||||||
|  | 	} | ||||||
|  | 	if err := convert_api_DaemonEndpoint_To_v1_DaemonEndpoint(&in.KubeletEndpoint, &out.KubeletEndpoint, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func convert_api_NodeList_To_v1_NodeList(in *api.NodeList, out *NodeList, s conversion.Scope) error { | func convert_api_NodeList_To_v1_NodeList(in *api.NodeList, out *NodeList, s conversion.Scope) error { | ||||||
| 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
| 		defaulting.(func(*api.NodeList))(in) | 		defaulting.(func(*api.NodeList))(in) | ||||||
| @@ -1130,6 +1148,9 @@ func convert_api_NodeStatus_To_v1_NodeStatus(in *api.NodeStatus, out *NodeStatus | |||||||
| 	} else { | 	} else { | ||||||
| 		out.Addresses = nil | 		out.Addresses = nil | ||||||
| 	} | 	} | ||||||
|  | 	if err := convert_api_NodeDaemonEndpoints_To_v1_NodeDaemonEndpoints(&in.DaemonEndpoints, &out.DaemonEndpoints, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
| 	if err := convert_api_NodeSystemInfo_To_v1_NodeSystemInfo(&in.NodeInfo, &out.NodeInfo, s); err != nil { | 	if err := convert_api_NodeSystemInfo_To_v1_NodeSystemInfo(&in.NodeInfo, &out.NodeInfo, s); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -2767,6 +2788,14 @@ func convert_v1_ContainerStatus_To_api_ContainerStatus(in *ContainerStatus, out | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func convert_v1_DaemonEndpoint_To_api_DaemonEndpoint(in *DaemonEndpoint, out *api.DaemonEndpoint, s conversion.Scope) error { | ||||||
|  | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
|  | 		defaulting.(func(*DaemonEndpoint))(in) | ||||||
|  | 	} | ||||||
|  | 	out.Port = in.Port | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func convert_v1_DeleteOptions_To_api_DeleteOptions(in *DeleteOptions, out *api.DeleteOptions, s conversion.Scope) error { | func convert_v1_DeleteOptions_To_api_DeleteOptions(in *DeleteOptions, out *api.DeleteOptions, s conversion.Scope) error { | ||||||
| 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
| 		defaulting.(func(*DeleteOptions))(in) | 		defaulting.(func(*DeleteOptions))(in) | ||||||
| @@ -3463,6 +3492,16 @@ func convert_v1_NodeCondition_To_api_NodeCondition(in *NodeCondition, out *api.N | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func convert_v1_NodeDaemonEndpoints_To_api_NodeDaemonEndpoints(in *NodeDaemonEndpoints, out *api.NodeDaemonEndpoints, s conversion.Scope) error { | ||||||
|  | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
|  | 		defaulting.(func(*NodeDaemonEndpoints))(in) | ||||||
|  | 	} | ||||||
|  | 	if err := convert_v1_DaemonEndpoint_To_api_DaemonEndpoint(&in.KubeletEndpoint, &out.KubeletEndpoint, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func convert_v1_NodeList_To_api_NodeList(in *NodeList, out *api.NodeList, s conversion.Scope) error { | func convert_v1_NodeList_To_api_NodeList(in *NodeList, out *api.NodeList, s conversion.Scope) error { | ||||||
| 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | 	if defaulting, found := s.DefaultingInterface(reflect.TypeOf(*in)); found { | ||||||
| 		defaulting.(func(*NodeList))(in) | 		defaulting.(func(*NodeList))(in) | ||||||
| @@ -3534,6 +3573,9 @@ func convert_v1_NodeStatus_To_api_NodeStatus(in *NodeStatus, out *api.NodeStatus | |||||||
| 	} else { | 	} else { | ||||||
| 		out.Addresses = nil | 		out.Addresses = nil | ||||||
| 	} | 	} | ||||||
|  | 	if err := convert_v1_NodeDaemonEndpoints_To_api_NodeDaemonEndpoints(&in.DaemonEndpoints, &out.DaemonEndpoints, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
| 	if err := convert_v1_NodeSystemInfo_To_api_NodeSystemInfo(&in.NodeInfo, &out.NodeInfo, s); err != nil { | 	if err := convert_v1_NodeSystemInfo_To_api_NodeSystemInfo(&in.NodeInfo, &out.NodeInfo, s); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -4851,6 +4893,7 @@ func init() { | |||||||
| 		convert_api_ContainerState_To_v1_ContainerState, | 		convert_api_ContainerState_To_v1_ContainerState, | ||||||
| 		convert_api_ContainerStatus_To_v1_ContainerStatus, | 		convert_api_ContainerStatus_To_v1_ContainerStatus, | ||||||
| 		convert_api_Container_To_v1_Container, | 		convert_api_Container_To_v1_Container, | ||||||
|  | 		convert_api_DaemonEndpoint_To_v1_DaemonEndpoint, | ||||||
| 		convert_api_DeleteOptions_To_v1_DeleteOptions, | 		convert_api_DeleteOptions_To_v1_DeleteOptions, | ||||||
| 		convert_api_DownwardAPIVolumeFile_To_v1_DownwardAPIVolumeFile, | 		convert_api_DownwardAPIVolumeFile_To_v1_DownwardAPIVolumeFile, | ||||||
| 		convert_api_DownwardAPIVolumeSource_To_v1_DownwardAPIVolumeSource, | 		convert_api_DownwardAPIVolumeSource_To_v1_DownwardAPIVolumeSource, | ||||||
| @@ -4891,6 +4934,7 @@ func init() { | |||||||
| 		convert_api_Namespace_To_v1_Namespace, | 		convert_api_Namespace_To_v1_Namespace, | ||||||
| 		convert_api_NodeAddress_To_v1_NodeAddress, | 		convert_api_NodeAddress_To_v1_NodeAddress, | ||||||
| 		convert_api_NodeCondition_To_v1_NodeCondition, | 		convert_api_NodeCondition_To_v1_NodeCondition, | ||||||
|  | 		convert_api_NodeDaemonEndpoints_To_v1_NodeDaemonEndpoints, | ||||||
| 		convert_api_NodeList_To_v1_NodeList, | 		convert_api_NodeList_To_v1_NodeList, | ||||||
| 		convert_api_NodeSpec_To_v1_NodeSpec, | 		convert_api_NodeSpec_To_v1_NodeSpec, | ||||||
| 		convert_api_NodeStatus_To_v1_NodeStatus, | 		convert_api_NodeStatus_To_v1_NodeStatus, | ||||||
| @@ -4968,6 +5012,7 @@ func init() { | |||||||
| 		convert_v1_ContainerState_To_api_ContainerState, | 		convert_v1_ContainerState_To_api_ContainerState, | ||||||
| 		convert_v1_ContainerStatus_To_api_ContainerStatus, | 		convert_v1_ContainerStatus_To_api_ContainerStatus, | ||||||
| 		convert_v1_Container_To_api_Container, | 		convert_v1_Container_To_api_Container, | ||||||
|  | 		convert_v1_DaemonEndpoint_To_api_DaemonEndpoint, | ||||||
| 		convert_v1_DeleteOptions_To_api_DeleteOptions, | 		convert_v1_DeleteOptions_To_api_DeleteOptions, | ||||||
| 		convert_v1_DownwardAPIVolumeFile_To_api_DownwardAPIVolumeFile, | 		convert_v1_DownwardAPIVolumeFile_To_api_DownwardAPIVolumeFile, | ||||||
| 		convert_v1_DownwardAPIVolumeSource_To_api_DownwardAPIVolumeSource, | 		convert_v1_DownwardAPIVolumeSource_To_api_DownwardAPIVolumeSource, | ||||||
| @@ -5008,6 +5053,7 @@ func init() { | |||||||
| 		convert_v1_Namespace_To_api_Namespace, | 		convert_v1_Namespace_To_api_Namespace, | ||||||
| 		convert_v1_NodeAddress_To_api_NodeAddress, | 		convert_v1_NodeAddress_To_api_NodeAddress, | ||||||
| 		convert_v1_NodeCondition_To_api_NodeCondition, | 		convert_v1_NodeCondition_To_api_NodeCondition, | ||||||
|  | 		convert_v1_NodeDaemonEndpoints_To_api_NodeDaemonEndpoints, | ||||||
| 		convert_v1_NodeList_To_api_NodeList, | 		convert_v1_NodeList_To_api_NodeList, | ||||||
| 		convert_v1_NodeSpec_To_api_NodeSpec, | 		convert_v1_NodeSpec_To_api_NodeSpec, | ||||||
| 		convert_v1_NodeStatus_To_api_NodeStatus, | 		convert_v1_NodeStatus_To_api_NodeStatus, | ||||||
|   | |||||||
| @@ -337,6 +337,11 @@ func deepCopy_v1_ContainerStatus(in ContainerStatus, out *ContainerStatus, c *co | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func deepCopy_v1_DaemonEndpoint(in DaemonEndpoint, out *DaemonEndpoint, c *conversion.Cloner) error { | ||||||
|  | 	out.Port = in.Port | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func deepCopy_v1_DeleteOptions(in DeleteOptions, out *DeleteOptions, c *conversion.Cloner) error { | func deepCopy_v1_DeleteOptions(in DeleteOptions, out *DeleteOptions, c *conversion.Cloner) error { | ||||||
| 	if err := deepCopy_v1_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | 	if err := deepCopy_v1_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -913,6 +918,13 @@ func deepCopy_v1_NodeCondition(in NodeCondition, out *NodeCondition, c *conversi | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func deepCopy_v1_NodeDaemonEndpoints(in NodeDaemonEndpoints, out *NodeDaemonEndpoints, c *conversion.Cloner) error { | ||||||
|  | 	if err := deepCopy_v1_DaemonEndpoint(in.KubeletEndpoint, &out.KubeletEndpoint, c); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func deepCopy_v1_NodeList(in NodeList, out *NodeList, c *conversion.Cloner) error { | func deepCopy_v1_NodeList(in NodeList, out *NodeList, c *conversion.Cloner) error { | ||||||
| 	if err := deepCopy_v1_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | 	if err := deepCopy_v1_TypeMeta(in.TypeMeta, &out.TypeMeta, c); err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -975,6 +987,9 @@ func deepCopy_v1_NodeStatus(in NodeStatus, out *NodeStatus, c *conversion.Cloner | |||||||
| 	} else { | 	} else { | ||||||
| 		out.Addresses = nil | 		out.Addresses = nil | ||||||
| 	} | 	} | ||||||
|  | 	if err := deepCopy_v1_NodeDaemonEndpoints(in.DaemonEndpoints, &out.DaemonEndpoints, c); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
| 	if err := deepCopy_v1_NodeSystemInfo(in.NodeInfo, &out.NodeInfo, c); err != nil { | 	if err := deepCopy_v1_NodeSystemInfo(in.NodeInfo, &out.NodeInfo, c); err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @@ -2240,6 +2255,7 @@ func init() { | |||||||
| 		deepCopy_v1_ContainerStateTerminated, | 		deepCopy_v1_ContainerStateTerminated, | ||||||
| 		deepCopy_v1_ContainerStateWaiting, | 		deepCopy_v1_ContainerStateWaiting, | ||||||
| 		deepCopy_v1_ContainerStatus, | 		deepCopy_v1_ContainerStatus, | ||||||
|  | 		deepCopy_v1_DaemonEndpoint, | ||||||
| 		deepCopy_v1_DeleteOptions, | 		deepCopy_v1_DeleteOptions, | ||||||
| 		deepCopy_v1_DownwardAPIVolumeFile, | 		deepCopy_v1_DownwardAPIVolumeFile, | ||||||
| 		deepCopy_v1_DownwardAPIVolumeSource, | 		deepCopy_v1_DownwardAPIVolumeSource, | ||||||
| @@ -2281,6 +2297,7 @@ func init() { | |||||||
| 		deepCopy_v1_Node, | 		deepCopy_v1_Node, | ||||||
| 		deepCopy_v1_NodeAddress, | 		deepCopy_v1_NodeAddress, | ||||||
| 		deepCopy_v1_NodeCondition, | 		deepCopy_v1_NodeCondition, | ||||||
|  | 		deepCopy_v1_NodeDaemonEndpoints, | ||||||
| 		deepCopy_v1_NodeList, | 		deepCopy_v1_NodeList, | ||||||
| 		deepCopy_v1_NodeSpec, | 		deepCopy_v1_NodeSpec, | ||||||
| 		deepCopy_v1_NodeStatus, | 		deepCopy_v1_NodeStatus, | ||||||
|   | |||||||
| @@ -1715,23 +1715,35 @@ type NodeSpec struct { | |||||||
| 	Unschedulable bool `json:"unschedulable,omitempty"` | 	Unschedulable bool `json:"unschedulable,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // DaemonEndpoint contains information about a single Daemon endpoint. | ||||||
|  | type DaemonEndpoint struct { | ||||||
|  | 	// Port number of the given endpoint. | ||||||
|  | 	Port int `json:port` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // NodeDaemonEndpoints lists ports opened by daemons running on the Node. | ||||||
|  | type NodeDaemonEndpoints struct { | ||||||
|  | 	// Endpoint on which Kubelet is listening. | ||||||
|  | 	KubeletEndpoint DaemonEndpoint `json:"kubeletEndpoint,omitempty"` | ||||||
|  | } | ||||||
|  |  | ||||||
| // NodeSystemInfo is a set of ids/uuids to uniquely identify the node. | // NodeSystemInfo is a set of ids/uuids to uniquely identify the node. | ||||||
| type NodeSystemInfo struct { | type NodeSystemInfo struct { | ||||||
| 	// MachineID is the machine-id reported by the node. | 	// Machine ID reported by the node. | ||||||
| 	MachineID string `json:"machineID"` | 	MachineID string `json:"machineID"` | ||||||
| 	// SystemUUID is the system-uuid reported by the node. | 	// System UUID reported by the node. | ||||||
| 	SystemUUID string `json:"systemUUID"` | 	SystemUUID string `json:"systemUUID"` | ||||||
| 	// BootID is the boot-id reported by the node. | 	// Boot ID reported by the node. | ||||||
| 	BootID string `json:"bootID"` | 	BootID string `json:"bootID"` | ||||||
| 	// Kernel version reported by the node from 'uname -r' (e.g. 3.16.0-0.bpo.4-amd64) | 	// Kernel Version reported by the node from 'uname -r' (e.g. 3.16.0-0.bpo.4-amd64). | ||||||
| 	KernelVersion string `json:"kernelVersion"` | 	KernelVersion string `json:"kernelVersion"` | ||||||
| 	// OS image used reported by the node from /etc/os-release (e.g. Debian GNU/Linux 7 (wheezy)) | 	// OS Image reported by the node from /etc/os-release (e.g. Debian GNU/Linux 7 (wheezy)). | ||||||
| 	OsImage string `json:"osImage"` | 	OsImage string `json:"osImage"` | ||||||
| 	// Container runtime version reported by the node through runtime remote API (e.g. docker://1.5.0) | 	// ContainerRuntime Version reported by the node through runtime remote API (e.g. docker://1.5.0). | ||||||
| 	ContainerRuntimeVersion string `json:"containerRuntimeVersion"` | 	ContainerRuntimeVersion string `json:"containerRuntimeVersion"` | ||||||
| 	// Kubelet version reported by the node. | 	// Kubelet Version reported by the node. | ||||||
| 	KubeletVersion string `json:"kubeletVersion"` | 	KubeletVersion string `json:"kubeletVersion"` | ||||||
| 	// Kube-proxy version reported by the node. | 	// KubeProxy Version reported by the node. | ||||||
| 	KubeProxyVersion string `json:"kubeProxyVersion"` | 	KubeProxyVersion string `json:"kubeProxyVersion"` | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1750,7 +1762,9 @@ type NodeStatus struct { | |||||||
| 	// Queried from cloud provider, if available. | 	// Queried from cloud provider, if available. | ||||||
| 	// More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses | 	// More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses | ||||||
| 	Addresses []NodeAddress `json:"addresses,omitempty" patchStrategy:"merge" patchMergeKey:"type"` | 	Addresses []NodeAddress `json:"addresses,omitempty" patchStrategy:"merge" patchMergeKey:"type"` | ||||||
| 	// NodeSystemInfo is a set of ids/uuids to uniquely identify the node. | 	// Endpoints of daemons running on the Node. | ||||||
|  | 	DaemonEndpoints NodeDaemonEndpoints `json:"daemonEndpoints,omitempty"` | ||||||
|  | 	// Set of ids/uuids to uniquely identify the node. | ||||||
| 	// More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info | 	// More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info | ||||||
| 	NodeInfo NodeSystemInfo `json:"nodeInfo,omitempty"` | 	NodeInfo NodeSystemInfo `json:"nodeInfo,omitempty"` | ||||||
| } | } | ||||||
|   | |||||||
| @@ -224,6 +224,15 @@ func (ContainerStatus) SwaggerDoc() map[string]string { | |||||||
| 	return map_ContainerStatus | 	return map_ContainerStatus | ||||||
| } | } | ||||||
|  |  | ||||||
|  | var map_DaemonEndpoint = map[string]string{ | ||||||
|  | 	"":     "DaemonEndpoint contains information about a single Daemon endpoint.", | ||||||
|  | 	"Port": "Port number of the given endpoint.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (DaemonEndpoint) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_DaemonEndpoint | ||||||
|  | } | ||||||
|  |  | ||||||
| var map_DeleteOptions = map[string]string{ | var map_DeleteOptions = map[string]string{ | ||||||
| 	"":                   "DeleteOptions may be provided when deleting an API object", | 	"":                   "DeleteOptions may be provided when deleting an API object", | ||||||
| 	"gracePeriodSeconds": "The duration in seconds before the object should be deleted. Value must be non-negative integer. The value zero indicates delete immediately. If this value is nil, the default grace period for the specified type will be used. Defaults to a per object value if not specified. zero means delete immediately.", | 	"gracePeriodSeconds": "The duration in seconds before the object should be deleted. Value must be non-negative integer. The value zero indicates delete immediately. If this value is nil, the default grace period for the specified type will be used. Defaults to a per object value if not specified. zero means delete immediately.", | ||||||
| @@ -653,6 +662,15 @@ func (NodeCondition) SwaggerDoc() map[string]string { | |||||||
| 	return map_NodeCondition | 	return map_NodeCondition | ||||||
| } | } | ||||||
|  |  | ||||||
|  | var map_NodeDaemonEndpoints = map[string]string{ | ||||||
|  | 	"":                "NodeDaemonEndpoints lists ports opened by daemons running on the Node.", | ||||||
|  | 	"kubeletEndpoint": "Endpoint on which Kubelet is listening.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (NodeDaemonEndpoints) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_NodeDaemonEndpoints | ||||||
|  | } | ||||||
|  |  | ||||||
| var map_NodeList = map[string]string{ | var map_NodeList = map[string]string{ | ||||||
| 	"":         "NodeList is the whole list of all Nodes which have been registered with master.", | 	"":         "NodeList is the whole list of all Nodes which have been registered with master.", | ||||||
| 	"metadata": "Standard list metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds", | 	"metadata": "Standard list metadata. More info: http://releases.k8s.io/HEAD/docs/devel/api-conventions.md#types-kinds", | ||||||
| @@ -681,7 +699,8 @@ var map_NodeStatus = map[string]string{ | |||||||
| 	"phase":           "NodePhase is the recently observed lifecycle phase of the node. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-phase", | 	"phase":           "NodePhase is the recently observed lifecycle phase of the node. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-phase", | ||||||
| 	"conditions":      "Conditions is an array of current observed node conditions. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-condition", | 	"conditions":      "Conditions is an array of current observed node conditions. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-condition", | ||||||
| 	"addresses":       "List of addresses reachable to the node. Queried from cloud provider, if available. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses", | 	"addresses":       "List of addresses reachable to the node. Queried from cloud provider, if available. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-addresses", | ||||||
| 	"nodeInfo":   "NodeSystemInfo is a set of ids/uuids to uniquely identify the node. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info", | 	"daemonEndpoints": "Endpoints of daemons running on the Node.", | ||||||
|  | 	"nodeInfo":        "Set of ids/uuids to uniquely identify the node. More info: http://releases.k8s.io/HEAD/docs/admin/node.md#node-info", | ||||||
| } | } | ||||||
|  |  | ||||||
| func (NodeStatus) SwaggerDoc() map[string]string { | func (NodeStatus) SwaggerDoc() map[string]string { | ||||||
| @@ -690,14 +709,14 @@ func (NodeStatus) SwaggerDoc() map[string]string { | |||||||
|  |  | ||||||
| var map_NodeSystemInfo = map[string]string{ | var map_NodeSystemInfo = map[string]string{ | ||||||
| 	"":                        "NodeSystemInfo is a set of ids/uuids to uniquely identify the node.", | 	"":                        "NodeSystemInfo is a set of ids/uuids to uniquely identify the node.", | ||||||
| 	"machineID":               "MachineID is the machine-id reported by the node.", | 	"machineID":               "Machine ID reported by the node.", | ||||||
| 	"systemUUID":              "SystemUUID is the system-uuid reported by the node.", | 	"systemUUID":              "System UUID reported by the node.", | ||||||
| 	"bootID":                  "BootID is the boot-id reported by the node.", | 	"bootID":                  "Boot ID reported by the node.", | ||||||
| 	"kernelVersion":           "Kernel version reported by the node from 'uname -r' (e.g. 3.16.0-0.bpo.4-amd64)", | 	"kernelVersion":           "Kernel Version reported by the node from 'uname -r' (e.g. 3.16.0-0.bpo.4-amd64).", | ||||||
| 	"osImage":                 "OS image used reported by the node from /etc/os-release (e.g. Debian GNU/Linux 7 (wheezy))", | 	"osImage":                 "OS Image reported by the node from /etc/os-release (e.g. Debian GNU/Linux 7 (wheezy)).", | ||||||
| 	"containerRuntimeVersion": "Container runtime version reported by the node through runtime remote API (e.g. docker://1.5.0)", | 	"containerRuntimeVersion": "ContainerRuntime Version reported by the node through runtime remote API (e.g. docker://1.5.0).", | ||||||
| 	"kubeletVersion":          "Kubelet version reported by the node.", | 	"kubeletVersion":          "Kubelet Version reported by the node.", | ||||||
| 	"kubeProxyVersion":        "Kube-proxy version reported by the node.", | 	"kubeProxyVersion":        "KubeProxy Version reported by the node.", | ||||||
| } | } | ||||||
|  |  | ||||||
| func (NodeSystemInfo) SwaggerDoc() map[string]string { | func (NodeSystemInfo) SwaggerDoc() map[string]string { | ||||||
|   | |||||||
| @@ -173,7 +173,8 @@ func NewMainKubelet( | |||||||
| 	pods int, | 	pods int, | ||||||
| 	dockerExecHandler dockertools.ExecHandler, | 	dockerExecHandler dockertools.ExecHandler, | ||||||
| 	resolverConfig string, | 	resolverConfig string, | ||||||
| 	cpuCFSQuota bool) (*Kubelet, error) { | 	cpuCFSQuota bool, | ||||||
|  | 	daemonEndpoints *api.NodeDaemonEndpoints) (*Kubelet, error) { | ||||||
| 	if rootDirectory == "" { | 	if rootDirectory == "" { | ||||||
| 		return nil, fmt.Errorf("invalid root directory %q", rootDirectory) | 		return nil, fmt.Errorf("invalid root directory %q", rootDirectory) | ||||||
| 	} | 	} | ||||||
| @@ -291,6 +292,7 @@ func NewMainKubelet( | |||||||
| 		syncLoopMonitor:                util.AtomicValue{}, | 		syncLoopMonitor:                util.AtomicValue{}, | ||||||
| 		resolverConfig:                 resolverConfig, | 		resolverConfig:                 resolverConfig, | ||||||
| 		cpuCFSQuota:                    cpuCFSQuota, | 		cpuCFSQuota:                    cpuCFSQuota, | ||||||
|  | 		daemonEndpoints:                daemonEndpoints, | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if plug, err := network.InitNetworkPlugin(networkPlugins, networkPluginName, &networkHost{klet}); err != nil { | 	if plug, err := network.InitNetworkPlugin(networkPlugins, networkPluginName, &networkHost{klet}); err != nil { | ||||||
| @@ -571,6 +573,9 @@ type Kubelet struct { | |||||||
|  |  | ||||||
| 	// True if container cpu limits should be enforced via cgroup CFS quota | 	// True if container cpu limits should be enforced via cgroup CFS quota | ||||||
| 	cpuCFSQuota bool | 	cpuCFSQuota bool | ||||||
|  |  | ||||||
|  | 	// Information about the ports which are opened by daemons on Node running this Kubelet server. | ||||||
|  | 	daemonEndpoints *api.NodeDaemonEndpoints | ||||||
| } | } | ||||||
|  |  | ||||||
| // getRootDir returns the full path to the directory under which kubelet can | // getRootDir returns the full path to the directory under which kubelet can | ||||||
| @@ -2324,6 +2329,8 @@ func (kl *Kubelet) setNodeStatus(node *api.Node) error { | |||||||
| 		node.Status.NodeInfo.KubeProxyVersion = version.Get().String() | 		node.Status.NodeInfo.KubeProxyVersion = version.Get().String() | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	node.Status.DaemonEndpoints = *kl.daemonEndpoints | ||||||
|  |  | ||||||
| 	// Check whether container runtime can be reported as up. | 	// Check whether container runtime can be reported as up. | ||||||
| 	containerRuntimeUp := kl.containerRuntimeUp() | 	containerRuntimeUp := kl.containerRuntimeUp() | ||||||
| 	// Check whether network is configured properly | 	// Check whether network is configured properly | ||||||
|   | |||||||
| @@ -109,6 +109,7 @@ func newTestKubelet(t *testing.T) *TestKubelet { | |||||||
| 	if err := kubelet.setupDataDirs(); err != nil { | 	if err := kubelet.setupDataDirs(); err != nil { | ||||||
| 		t.Fatalf("can't initialize kubelet data dirs: %v", err) | 		t.Fatalf("can't initialize kubelet data dirs: %v", err) | ||||||
| 	} | 	} | ||||||
|  | 	kubelet.daemonEndpoints = &api.NodeDaemonEndpoints{} | ||||||
| 	mockCadvisor := &cadvisor.Mock{} | 	mockCadvisor := &cadvisor.Mock{} | ||||||
| 	kubelet.cadvisor = mockCadvisor | 	kubelet.cadvisor = mockCadvisor | ||||||
| 	podManager, fakeMirrorClient := newFakePodManager() | 	podManager, fakeMirrorClient := newFakePodManager() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 gmarek
					gmarek