Fetch the repository succeeded.
package node
import (
v1 "github.com/rancher/types/apis/core/v1"
v3 "github.com/rancher/types/apis/management.cattle.io/v3"
corev1 "k8s.io/api/core/v1"
apierrors "k8s.io/apimachinery/pkg/api/errors"
"k8s.io/apimachinery/pkg/labels"
)
const (
externalAddressAnnotation = "rke.cattle.io/external-ip"
LabelNodeName = "management.cattle.io/nodename"
)
func GetNodeName(node *v3.Node) string {
if node.Status.NodeName != "" {
return node.Status.NodeName
}
// to handle the case when node was provisioned first
if node.Status.NodeConfig != nil {
if node.Status.NodeConfig.HostnameOverride != "" {
return node.Status.NodeConfig.HostnameOverride
}
}
return ""
}
func IsNodeForNode(node *corev1.Node, machine *v3.Node) bool {
nodeName := GetNodeName(machine)
if nodeName == node.Name {
return true
}
machineAddress := ""
if machine.Status.NodeConfig != nil {
if machine.Status.NodeConfig.InternalAddress == "" {
// rke defaults internal address to address
machineAddress = machine.Status.NodeConfig.Address
} else {
machineAddress = machine.Status.NodeConfig.InternalAddress
}
}
if machineAddress == "" {
return false
}
if machineAddress == GetNodeInternalAddress(node) {
return true
}
return false
}
func GetNodeInternalAddress(node *corev1.Node) string {
for _, address := range node.Status.Addresses {
if address.Type == corev1.NodeInternalIP {
return address.Address
}
}
return ""
}
func GetEndpointNodeIP(node *v3.Node) string {
externalIP := ""
internalIP := ""
for _, ip := range node.Status.InternalNodeStatus.Addresses {
if ip.Type == "ExternalIP" && ip.Address != "" {
externalIP = ip.Address
break
} else if ip.Type == "InternalIP" && ip.Address != "" {
internalIP = ip.Address
}
}
if externalIP != "" {
return externalIP
}
if node.Annotations != nil {
externalIP = node.Status.NodeAnnotations[externalAddressAnnotation]
if externalIP != "" {
return externalIP
}
}
return internalIP
}
func GetNodeByNodeName(nodes []*v3.Node, nodeName string) *v3.Node {
for _, m := range nodes {
if GetNodeName(m) == nodeName {
return m
}
}
return nil
}
func GetNodeForMachine(machine *v3.Node, nodeLister v1.NodeLister) (*corev1.Node, error) {
nodeName := ""
if machine.Labels != nil {
nodeName = machine.Labels[LabelNodeName]
}
var nodes []*corev1.Node
var err error
if nodeName != "" {
node, err := nodeLister.Get("", nodeName)
if err != nil && !apierrors.IsNotFound(err) {
return nil, err
}
if node != nil {
nodes = append(nodes, node)
}
}
if len(nodes) == 0 {
nodes, err = nodeLister.List("", labels.NewSelector())
if err != nil {
return nil, err
}
}
for _, n := range nodes {
if IsNodeForNode(n, machine) {
return n, nil
}
}
return nil, nil
}
func GetMachineForNode(node *corev1.Node, clusterNamespace string, machineLister v3.NodeLister) (*v3.Node, error) {
labelsSearchSet := labels.Set{LabelNodeName: node.Name}
machines, err := machineLister.List(clusterNamespace, labels.SelectorFromSet(labelsSearchSet))
if err != nil {
return nil, err
}
if len(machines) == 0 {
machines, err = machineLister.List(clusterNamespace, labels.NewSelector())
if err != nil {
return nil, err
}
}
for _, machine := range machines {
if IsNodeForNode(node, machine) {
return machine, nil
}
}
return nil, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。