在 AWS 中的 Kubernetes 节点上,您将填充一些内容作为节点标签的一部分和节点元数据的各种其他部分:
kubectl get nodes -o json | jq '.items[].metadata.labels'
{
"beta.kubernetes.io/arch": "amd64",
"beta.kubernetes.io/instance-type": "c5.large",
"beta.kubernetes.io/os": "linux",
"failure-domain.beta.kubernetes.io/region": "us-east-1",
"failure-domain.beta.kubernetes.io/zone": "us-east-1b",
"kubernetes.io/hostname": "<hostname>",
"kubernetes.io/role": "master",
"manufacturer": "amazon_ec2",
"node-role.kubernetes.io/master": "",
"operatingsystem": "centos",
"tier": "production",
"virtual": "kvm"
}
节点信息在node package here中的client-go中使用Get方法。这是一个例子:
client := kubernetes.NewForConfigOrDie(config)
list, err := client.CoreV1().Nodes().List(metav1.ListOptions{})
if err != nil {
fmt.Fprintf(os.Stderr, "error listing nodes: %v", err)
os.Exit(1)
}
for _, node := range list.Items {
fmt.Printf("Node: %s\n", node.Name)
node, err := client.CoreV1().Nodes().Get(node.Name, metav1.GetOptions{})
if err != nil {
fmt.Fprintf(os.Stderr, "error getting node: %v", err)
os.Exit(1)
}
fmt.Println(node)
}
然而这真的可能不是你想要的方式。如果您在 AWS 的 kops 集群上运行此程序,则运行工作负载的节点已经可以访问 AWS API 以及查询节点数据所需的 IAM role。
考虑到这一点,请考虑改用AWS Go SDK。你可以很容易地查询 EC2,这是一个adapted example:
package main
import (
"fmt"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/ec2"
)
func main() {
// Load session from shared config
sess := session.Must(session.NewSessionWithOptions(session.Options{
SharedConfigState: session.SharedConfigEnable,
}))
// Create new EC2 client
ec2Svc := ec2.New(sess)
// Call to get detailed information on each instance
result, err := ec2Svc.DescribeInstances(nil)
if err != nil {
fmt.Println("Error", err)
} else {
fmt.Println("Success", result)
}
}