mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-25 01:20:18 +00:00 
			
		
		
		
	This deals with the case that a user can configure cri-o to use /run/crio/crio.sock and get very confusing behavior. See https://github.com/cri-o/cri-o/issues/7010#issuecomment-1594149469
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2015 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 cadvisor
 | |
| 
 | |
| import (
 | |
| 	"strings"
 | |
| 
 | |
| 	cadvisorapi "github.com/google/cadvisor/info/v1"
 | |
| 	cadvisorapi2 "github.com/google/cadvisor/info/v2"
 | |
| 	"k8s.io/api/core/v1"
 | |
| 	"k8s.io/apimachinery/pkg/api/resource"
 | |
| 	v1helper "k8s.io/kubernetes/pkg/apis/core/v1/helper"
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	// CrioSocketSuffix is the path to the CRI-O socket.
 | |
| 	// Please keep this in sync with the one in:
 | |
| 	// github.com/google/cadvisor/tree/master/container/crio/client.go
 | |
| 	// Note that however we only match on the suffix, as /var/run is often a
 | |
| 	// symlink to /run, so the user can specify either path.
 | |
| 	CrioSocketSuffix = "run/crio/crio.sock"
 | |
| )
 | |
| 
 | |
| // CapacityFromMachineInfo returns the capacity of the resources from the machine info.
 | |
| func CapacityFromMachineInfo(info *cadvisorapi.MachineInfo) v1.ResourceList {
 | |
| 	c := v1.ResourceList{
 | |
| 		v1.ResourceCPU: *resource.NewMilliQuantity(
 | |
| 			int64(info.NumCores*1000),
 | |
| 			resource.DecimalSI),
 | |
| 		v1.ResourceMemory: *resource.NewQuantity(
 | |
| 			int64(info.MemoryCapacity),
 | |
| 			resource.BinarySI),
 | |
| 	}
 | |
| 
 | |
| 	// if huge pages are enabled, we report them as a schedulable resource on the node
 | |
| 	for _, hugepagesInfo := range info.HugePages {
 | |
| 		pageSizeBytes := int64(hugepagesInfo.PageSize * 1024)
 | |
| 		hugePagesBytes := pageSizeBytes * int64(hugepagesInfo.NumPages)
 | |
| 		pageSizeQuantity := resource.NewQuantity(pageSizeBytes, resource.BinarySI)
 | |
| 		c[v1helper.HugePageResourceName(*pageSizeQuantity)] = *resource.NewQuantity(hugePagesBytes, resource.BinarySI)
 | |
| 	}
 | |
| 
 | |
| 	return c
 | |
| }
 | |
| 
 | |
| // EphemeralStorageCapacityFromFsInfo returns the capacity of the ephemeral storage from the FsInfo.
 | |
| func EphemeralStorageCapacityFromFsInfo(info cadvisorapi2.FsInfo) v1.ResourceList {
 | |
| 	c := v1.ResourceList{
 | |
| 		v1.ResourceEphemeralStorage: *resource.NewQuantity(
 | |
| 			int64(info.Capacity),
 | |
| 			resource.BinarySI),
 | |
| 	}
 | |
| 	return c
 | |
| }
 | |
| 
 | |
| // UsingLegacyCadvisorStats returns true if container stats are provided by cadvisor instead of through the CRI.
 | |
| // CRI integrations should get container metrics via CRI.
 | |
| // TODO: cri-o relies on cadvisor as a temporary workaround. The code should
 | |
| // be removed. Related issue:
 | |
| // https://github.com/kubernetes/kubernetes/issues/51798
 | |
| func UsingLegacyCadvisorStats(runtimeEndpoint string) bool {
 | |
| 	return strings.HasSuffix(runtimeEndpoint, CrioSocketSuffix)
 | |
| }
 |