2019-09-27 21:51:53 +00:00
|
|
|
// +build !providerless
|
|
|
|
|
|
|
|
/*
|
|
|
|
Copyright 2017 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 azure
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/Azure/azure-sdk-for-go/services/compute/mgmt/2019-07-01/compute"
|
|
|
|
"github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network"
|
|
|
|
|
|
|
|
v1 "k8s.io/api/core/v1"
|
|
|
|
"k8s.io/apimachinery/pkg/types"
|
|
|
|
cloudprovider "k8s.io/cloud-provider"
|
|
|
|
)
|
|
|
|
|
|
|
|
// VMSet defines functions all vmsets (including scale set and availability
|
|
|
|
// set) should be implemented.
|
|
|
|
type VMSet interface {
|
|
|
|
// GetInstanceIDByNodeName gets the cloud provider ID by node name.
|
|
|
|
// It must return ("", cloudprovider.InstanceNotFound) if the instance does
|
|
|
|
// not exist or is no longer running.
|
|
|
|
GetInstanceIDByNodeName(name string) (string, error)
|
|
|
|
// GetInstanceTypeByNodeName gets the instance type by node name.
|
|
|
|
GetInstanceTypeByNodeName(name string) (string, error)
|
|
|
|
// GetIPByNodeName gets machine private IP and public IP by node name.
|
|
|
|
GetIPByNodeName(name string) (string, string, error)
|
|
|
|
// GetPrimaryInterface gets machine primary network interface by node name.
|
|
|
|
GetPrimaryInterface(nodeName string) (network.Interface, error)
|
|
|
|
// GetNodeNameByProviderID gets the node name by provider ID.
|
|
|
|
GetNodeNameByProviderID(providerID string) (types.NodeName, error)
|
|
|
|
|
|
|
|
// GetZoneByNodeName gets cloudprovider.Zone by node name.
|
|
|
|
GetZoneByNodeName(name string) (cloudprovider.Zone, error)
|
|
|
|
|
|
|
|
// GetPrimaryVMSetName returns the VM set name depending on the configured vmType.
|
|
|
|
// It returns config.PrimaryScaleSetName for vmss and config.PrimaryAvailabilitySetName for standard vmType.
|
|
|
|
GetPrimaryVMSetName() string
|
|
|
|
// GetVMSetNames selects all possible availability sets or scale sets
|
|
|
|
// (depending vmType configured) for service load balancer, if the service has
|
|
|
|
// no loadbalancer mode annotation returns the primary VMSet. If service annotation
|
|
|
|
// for loadbalancer exists then return the eligible VMSet.
|
|
|
|
GetVMSetNames(service *v1.Service, nodes []*v1.Node) (availabilitySetNames *[]string, err error)
|
|
|
|
// EnsureHostsInPool ensures the given Node's primary IP configurations are
|
|
|
|
// participating in the specified LoadBalancer Backend Pool.
|
|
|
|
EnsureHostsInPool(service *v1.Service, nodes []*v1.Node, backendPoolID string, vmSetName string, isInternal bool) error
|
|
|
|
// EnsureHostInPool ensures the given VM's Primary NIC's Primary IP Configuration is
|
|
|
|
// participating in the specified LoadBalancer Backend Pool.
|
|
|
|
EnsureHostInPool(service *v1.Service, nodeName types.NodeName, backendPoolID string, vmSetName string, isInternal bool) error
|
|
|
|
// EnsureBackendPoolDeleted ensures the loadBalancer backendAddressPools deleted from the specified nodes.
|
|
|
|
EnsureBackendPoolDeleted(service *v1.Service, backendPoolID, vmSetName string, backendAddressPools *[]network.BackendAddressPool) error
|
|
|
|
|
|
|
|
// AttachDisk attaches a vhd to vm. The vhd must exist, can be identified by diskName, diskURI, and lun.
|
|
|
|
AttachDisk(isManagedDisk bool, diskName, diskURI string, nodeName types.NodeName, lun int32, cachingMode compute.CachingTypes) error
|
|
|
|
// DetachDisk detaches a vhd from host. The vhd can be identified by diskName or diskURI.
|
|
|
|
DetachDisk(diskName, diskURI string, nodeName types.NodeName) (*http.Response, error)
|
|
|
|
// GetDataDisks gets a list of data disks attached to the node.
|
2019-11-14 18:56:24 +00:00
|
|
|
GetDataDisks(nodeName types.NodeName, crt cacheReadType) ([]compute.DataDisk, error)
|
2019-09-27 21:51:53 +00:00
|
|
|
|
|
|
|
// GetPowerStatusByNodeName returns the power state of the specified node.
|
|
|
|
GetPowerStatusByNodeName(name string) (string, error)
|
|
|
|
|
|
|
|
// GetPrivateIPsByNodeName returns a slice of all private ips assigned to node (ipv6 and ipv4)
|
|
|
|
GetPrivateIPsByNodeName(name string) ([]string, error)
|
|
|
|
}
|