2 回答
TA贡献1828条经验 获得超3个赞
如何做到这一点取决于你想做什么。
部署
包含一个 PodTemplate ,Deployment用于创建每个副本。
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: myapp
name: myapp
spec:
replicas: 2
selector:
matchLabels:
app: myapp
template:
metadata:
labels:
app: myapp
spec:
containers:
- image: myimage
name: myapp
livenessProbe:
# your desired liveness check
您可以使用 client-go 从部署中获取所需的 PodTemplate
例如:
clientset := kubernetes.NewForConfigOrDie(config)
deploymentClient := clientset.AppsV1().Deployments("mynamespace")
deployment, err := deploymentClient.Get("myapp", metav1.GetOptions{})
for _, container := range deployment.Spec.Template.Spec.Containers {
container.LivenessProbe // add your logic
}
注意:仅Deployment包含所需的 PodTemplate,因此要查看任何状态,您必须查看已创建的 Pod。
豆荚
您可以使用与.Deployment
Pod 示例列表:
pods, err := clientset.CoreV1().Pods(namespace).List(metav1.ListOptions{
LabelSelector: "app=myapp",
})
// check the status for the pods - to see Probe status
for _, pod := range pods.Items {
pod.Status.Conditions // use your custom logic here
for _, container := range pod.Status.ContainerStatuses {
container.RestartCount // use this number in your logic
}
}
包含一些-information 和with的Status部分,也在上面的 Go 示例中进行了说明。使用您的自定义逻辑来使用此信息。Podconditions:ProbecontainerStatuses:restartCount:
每当livenessProbe失败时,Pod 都会重新启动。
一个例子Pod Status
status:
conditions:
- lastProbeTime: null
lastTransitionTime: "2020-09-15T07:17:25Z"
status: "True"
type: Initialized
containerStatuses:
- containerID: docker://25b28170c8cec18ca3af0e9c792620a3edaf36aed02849d08c56b78610dec31b
image: myimage
imageID: docker-pullable://myimage@sha256:a432251b2674d24858f72b1392033e0d7a79786425555714d8e9a656505fa08c
name: myapp
restartCount: 0
TA贡献1772条经验 获得超8个赞
pods, err := client.CoreV1().Pods("").List(meta_v1.ListOptions{})
if err != nil {
log.Fatal(err)
}
for _, pod := range pods.Items {
for _, container := range pod.Spec.Containers {
fmt.Println(container.LivenessProbe)
fmt.Println(container.ReadinessProbe)
}
}
您可以遍历 pod.Items 以获取容器 LivenessProbe 和 ReadinessProbe
- 2 回答
- 0 关注
- 206 浏览
添加回答
举报
