mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-31 05:40:42 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			99 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2018 The Kubernetes Authors.
 | |
| 
 | |
| Licensed under the Apache License, Version 2.0 (the "License");
 | |
| you may not use this file except in compliance with the License.
 | |
| You may obtain a copy of the License at
 | |
| 
 | |
|     http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
| Unless required by applicable law or agreed to in writing, software
 | |
| distributed under the License is distributed on an "AS IS" BASIS,
 | |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| See the License for the specific language governing permissions and
 | |
| limitations under the License.
 | |
| */
 | |
| 
 | |
| package podresources
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 
 | |
| 	utilfeature "k8s.io/apiserver/pkg/util/feature"
 | |
| 	kubefeatures "k8s.io/kubernetes/pkg/features"
 | |
| 	"k8s.io/kubernetes/pkg/kubelet/metrics"
 | |
| 
 | |
| 	"k8s.io/kubelet/pkg/apis/podresources/v1"
 | |
| )
 | |
| 
 | |
| // podResourcesServerV1alpha1 implements PodResourcesListerServer
 | |
| type v1PodResourcesServer struct {
 | |
| 	podsProvider    PodsProvider
 | |
| 	devicesProvider DevicesProvider
 | |
| 	cpusProvider    CPUsProvider
 | |
| 	memoryProvider  MemoryProvider
 | |
| }
 | |
| 
 | |
| // NewV1PodResourcesServer returns a PodResourcesListerServer which lists pods provided by the PodsProvider
 | |
| // with device information provided by the DevicesProvider
 | |
| func NewV1PodResourcesServer(podsProvider PodsProvider, devicesProvider DevicesProvider, cpusProvider CPUsProvider, memoryProvider MemoryProvider) v1.PodResourcesListerServer {
 | |
| 	return &v1PodResourcesServer{
 | |
| 		podsProvider:    podsProvider,
 | |
| 		devicesProvider: devicesProvider,
 | |
| 		cpusProvider:    cpusProvider,
 | |
| 		memoryProvider:  memoryProvider,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // List returns information about the resources assigned to pods on the node
 | |
| func (p *v1PodResourcesServer) List(ctx context.Context, req *v1.ListPodResourcesRequest) (*v1.ListPodResourcesResponse, error) {
 | |
| 	metrics.PodResourcesEndpointRequestsTotalCount.WithLabelValues("v1").Inc()
 | |
| 	metrics.PodResourcesEndpointRequestsListCount.WithLabelValues("v1").Inc()
 | |
| 
 | |
| 	pods := p.podsProvider.GetPods()
 | |
| 	podResources := make([]*v1.PodResources, len(pods))
 | |
| 	p.devicesProvider.UpdateAllocatedDevices()
 | |
| 
 | |
| 	for i, pod := range pods {
 | |
| 		pRes := v1.PodResources{
 | |
| 			Name:       pod.Name,
 | |
| 			Namespace:  pod.Namespace,
 | |
| 			Containers: make([]*v1.ContainerResources, len(pod.Spec.Containers)),
 | |
| 		}
 | |
| 
 | |
| 		for j, container := range pod.Spec.Containers {
 | |
| 			pRes.Containers[j] = &v1.ContainerResources{
 | |
| 				Name:    container.Name,
 | |
| 				Devices: p.devicesProvider.GetDevices(string(pod.UID), container.Name),
 | |
| 				CpuIds:  p.cpusProvider.GetCPUs(string(pod.UID), container.Name),
 | |
| 				Memory:  p.memoryProvider.GetMemory(string(pod.UID), container.Name),
 | |
| 			}
 | |
| 		}
 | |
| 		podResources[i] = &pRes
 | |
| 	}
 | |
| 
 | |
| 	return &v1.ListPodResourcesResponse{
 | |
| 		PodResources: podResources,
 | |
| 	}, nil
 | |
| }
 | |
| 
 | |
| // GetAllocatableResources returns information about all the resources known by the server - this more like the capacity, not like the current amount of free resources.
 | |
| func (p *v1PodResourcesServer) GetAllocatableResources(ctx context.Context, req *v1.AllocatableResourcesRequest) (*v1.AllocatableResourcesResponse, error) {
 | |
| 	metrics.PodResourcesEndpointRequestsTotalCount.WithLabelValues("v1").Inc()
 | |
| 	metrics.PodResourcesEndpointRequestsGetAllocatableCount.WithLabelValues("v1").Inc()
 | |
| 
 | |
| 	if !utilfeature.DefaultFeatureGate.Enabled(kubefeatures.KubeletPodResourcesGetAllocatable) {
 | |
| 		metrics.PodResourcesEndpointErrorsGetAllocatableCount.WithLabelValues("v1").Inc()
 | |
| 		return nil, fmt.Errorf("Pod Resources API GetAllocatableResources disabled")
 | |
| 	}
 | |
| 
 | |
| 	metrics.PodResourcesEndpointRequestsTotalCount.WithLabelValues("v1").Inc()
 | |
| 
 | |
| 	return &v1.AllocatableResourcesResponse{
 | |
| 		Devices: p.devicesProvider.GetAllocatableDevices(),
 | |
| 		CpuIds:  p.cpusProvider.GetAllocatableCPUs(),
 | |
| 		Memory:  p.memoryProvider.GetAllocatableMemory(),
 | |
| 	}, nil
 | |
| }
 |