2018-05-23 16:50:43 +00:00
|
|
|
/*
|
|
|
|
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 util
|
|
|
|
|
2018-08-13 23:38:30 +00:00
|
|
|
import (
|
|
|
|
"crypto/sha1"
|
|
|
|
"encoding/hex"
|
|
|
|
)
|
|
|
|
|
2018-05-23 16:50:43 +00:00
|
|
|
// This file is a common place holder for volume limit utility constants
|
|
|
|
// shared between volume package and scheduler
|
|
|
|
|
|
|
|
const (
|
|
|
|
// EBSVolumeLimitKey resource name that will store volume limits for EBS
|
|
|
|
EBSVolumeLimitKey = "attachable-volumes-aws-ebs"
|
Resolves #59015, extends existing regex to cover t3, r5(d) & z1d instance types
From current AWS documentation:
https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/volume_limits.html
T3, C5, C5d, M5, M5d, R5, R5d, and z1d instances support a maximum of
28 attachments, and every instance has at least one network interface
attachment. If you have no additional network interface attachments on
these instances, you could attach 27 EBS volumes.
2018-08-31 13:06:16 +00:00
|
|
|
// EBSNitroLimitRegex finds nitro instance types with different limit than EBS defaults
|
|
|
|
EBSNitroLimitRegex = "^[cmr]5.*|t3|z1d"
|
|
|
|
// DefaultMaxEBSVolumes is the limit for volumes attached to an instance.
|
|
|
|
// Amazon recommends no more than 40; the system root volume uses at least one.
|
|
|
|
// See http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/volume_limits.html#linux-specific-volume-limits
|
|
|
|
DefaultMaxEBSVolumes = 39
|
2018-09-10 21:22:15 +00:00
|
|
|
// DefaultMaxEBSNitroVolumeLimit is default EBS volume limit on m5 and c5 instances
|
Resolves #59015, extends existing regex to cover t3, r5(d) & z1d instance types
From current AWS documentation:
https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/volume_limits.html
T3, C5, C5d, M5, M5d, R5, R5d, and z1d instances support a maximum of
28 attachments, and every instance has at least one network interface
attachment. If you have no additional network interface attachments on
these instances, you could attach 27 EBS volumes.
2018-08-31 13:06:16 +00:00
|
|
|
DefaultMaxEBSNitroVolumeLimit = 25
|
2018-05-23 16:50:43 +00:00
|
|
|
// AzureVolumeLimitKey stores resource name that will store volume limits for Azure
|
|
|
|
AzureVolumeLimitKey = "attachable-volumes-azure-disk"
|
|
|
|
// GCEVolumeLimitKey stores resource name that will store volume limits for GCE node
|
|
|
|
GCEVolumeLimitKey = "attachable-volumes-gce-pd"
|
2018-08-13 23:38:30 +00:00
|
|
|
|
2019-01-16 19:05:35 +00:00
|
|
|
// CinderVolumeLimitKey contains Volume limit key for Cinder
|
|
|
|
CinderVolumeLimitKey = "attachable-volumes-cinder"
|
2018-12-06 16:12:51 +00:00
|
|
|
// DefaultMaxCinderVolumes defines the maximum number of PD Volumes for Cinder
|
|
|
|
// For Openstack we are keeping this to a high enough value so as depending on backend
|
|
|
|
// cluster admins can configure it.
|
|
|
|
DefaultMaxCinderVolumes = 256
|
|
|
|
|
2018-08-13 23:38:30 +00:00
|
|
|
// CSIAttachLimitPrefix defines prefix used for CSI volumes
|
|
|
|
CSIAttachLimitPrefix = "attachable-volumes-csi-"
|
|
|
|
|
|
|
|
// ResourceNameLengthLimit stores maximum allowed Length for a ResourceName
|
|
|
|
ResourceNameLengthLimit = 63
|
2018-05-23 16:50:43 +00:00
|
|
|
)
|
2018-08-13 23:38:30 +00:00
|
|
|
|
|
|
|
// GetCSIAttachLimitKey returns limit key used for CSI volumes
|
|
|
|
func GetCSIAttachLimitKey(driverName string) string {
|
|
|
|
csiPrefixLength := len(CSIAttachLimitPrefix)
|
|
|
|
totalkeyLength := csiPrefixLength + len(driverName)
|
|
|
|
if totalkeyLength >= ResourceNameLengthLimit {
|
|
|
|
charsFromDriverName := driverName[:23]
|
|
|
|
hash := sha1.New()
|
|
|
|
hash.Write([]byte(driverName))
|
|
|
|
hashed := hex.EncodeToString(hash.Sum(nil))
|
|
|
|
hashed = hashed[:16]
|
|
|
|
return CSIAttachLimitPrefix + charsFromDriverName + hashed
|
|
|
|
}
|
|
|
|
return CSIAttachLimitPrefix + driverName
|
|
|
|
}
|