Reg*_*ult 52 kubernetes kubectl
查看http://kubernetes.io/docs/user-guide/labels/#selecting-sets-of-nodes,看起来可以根据标签选择一定范围的pod.但在我的情况下,我想选择一个节点上的所有pod,但我不想在相应的节点上标记每个pod.
我是否遗漏了文档中的内容,或者是否无法按节点选择?如果我做:
kubectl --server="<SERVER>" --namespace=<NS> get pods -o wide | head
NAME READY STATUS RESTARTS AGE NODE
Run Code Online (Sandbox Code Playgroud)
这些标题中的任何一个都可以用作选择器吗?如果是,最重要的是如何使用kubectl bust,如何使用API?
提前致谢
Cam*_*mil 77
按nodeName排序pod的示例:
kubectl get pods -o wide --sort-by="{.spec.nodeName}"
Run Code Online (Sandbox Code Playgroud)
使用标签过滤器在节点上获取pod的示例:
for n in $(kubectl get nodes -l your_label_key=your_label_value --no-headers | cut -d " " -f1); do
kubectl get pods --all-namespaces --no-headers --field-selector spec.nodeName=${n}
done
Run Code Online (Sandbox Code Playgroud)
或者按重启次数计算
kubectl get pods --sort-by="{.status.containerStatuses[:1].restartCount}"
Run Code Online (Sandbox Code Playgroud)
使用--template标志按nodeName过滤的示例:
$ kubectl get nodes
NAME STATUS AGE
ip-10-0-90-30.ec2.internal Ready 2d
ip-10-0-90-35.ec2.internal Ready 2d
ip-10-0-90-50.ec2.internal Ready,SchedulingDisabled 2d
ip-10-0-91-60.ec2.internal Ready 2d
ip-10-0-91-65.ec2.internal Ready 2d
$kubectl get pods --template '{{range .items}}{{if eq .spec.nodeName "ip-10-0-90-30.ec2.internal"}}{{.metadata.name}}{{"\n"}}{{end}}}{{end}}'
filebeat-pezch
app-5xole
node-exporter-6kfs8
prometheus-0
sso-359976856-wu8zt
Run Code Online (Sandbox Code Playgroud)
Kri*_*fer 66
如接受的答案所述,PR现在已合并,您可以按节点获取pod,如下所示:
kubectl get pods --all-namespaces -o wide --field-selector spec.nodeName=<node>
Run Code Online (Sandbox Code Playgroud)
小智 12
您还可以使用以下命令查询节点的所有窗格
kubectl get pods -o wide --all-namespaces | grep <YOUR-NODE>
Run Code Online (Sandbox Code Playgroud)
像这样在Kubernetes API服务器端支持所需的内容:
curl --cacert ca.crt --cert apiserver.crt --key apiserver.key https://<server>:<port>/api/v1/namespaces/<namespace>/pods?fieldSelector=spec.nodeName%3Dsomenodename
Run Code Online (Sandbox Code Playgroud)
但是该字段选择器选项尚未内置kubectl:https : //github.com/kubernetes/kubernetes/pull/50140
我在 Go 客户端上经历了相同的过程,它发现了 CLI 所采用的一些快捷方式。
func doNodesHavePods(clientset *kubernetes.Clientset) error {
nodeLabelSelector := "nodelabel=interesting_nodes"
nodes, err := clientset.CoreV1().Nodes().List(metav1.ListOptions{LabelSelector: nodeLabelSelector})
if err != nil {
return err
}
nodeNames := []string{}
for _, node := range nodes.Items {
nodeNames = append(nodeNames, node.Name)
}
// --all-namespaces -> listing and looping on namespaces
namespaces, err := clientset.CoreV1().Namespaces().List(metav1.ListOptions{})
if err != nil {
return err
}
for _, namespace := range namespaces.Items {
for _, name := range nodeNames {
// pods need a namespace to be listed.
pods, err := clientset.CoreV1().Pods(namespace.Name).List(metav1.ListOptions{FieldSelector: "spec.nodeName=" + name})
if err != nil {
println("%v", err)
}
for _, pod := range pods.Items {
fmt.Println(pod.Namespace, pod.Name)
}
}
}
return nil
}
Run Code Online (Sandbox Code Playgroud)
我开始发现我需要问的很多问题对于 CLI 来说变得过于复杂,CLI 是一个很好的主力,但是学习使用 Go 客户端可以帮助您获得您正在寻找的第一个答案,但是还深入挖掘这些答案提出的问题。
| 归档时间: |
|
| 查看次数: |
39118 次 |
| 最近记录: |