世界最资讯丨kubernetes就绪探针使用
假设我们有一个应用程序,它需要一段时间来初始化并准备好接收流量。我们可以使用就绪探针来确保容器已准备好接收流量后才将其暴露给外部服务。
【资料图】
我们首先创建一个Deployment对象来运行应用程序。Deployment对象将自动创建一个副本集(ReplicaSet),并在其中运行指定数量的Pod。我们将使用nginx镜像作为应用程序的示例。
apiVersion: apps/v1kind: Deploymentmetadata: name: nginx-deploymentspec: replicas: 3 selector: matchLabels: app: nginx template: metadata: labels: app: nginx spec: containers: - name: nginx-container image: nginx ports: - containerPort: 80 readinessProbe: httpGet: path: / port: 80
在上面的示例中,我们创建了一个名为nginx-deployment的Deployment对象,并指定了需要运行3个Pod副本。每个Pod都运行一个名为nginx-container的容器,该容器使用nginx镜像,并在80端口上监听流量。我们还将就绪探针配置为使用httpGet方法,向容器的/路径发送HTTP GET请求来检查容器是否已准备好接收流量。
我们可以通过kubectl命令检查Deployment的状态:
kubectl get deployment nginx-deployment
输出应该类似于:
NAME READY UP-TO-DATE AVAILABLE AGEnginx-deployment 3/3 3 3 10s
上面的输出显示了Deployment中有3个Pod副本,所有的副本都已准备好,可以接收流量。
接下来,我们可以创建一个Service对象来暴露Deployment中的Pod给外部服务。Service对象将使用负载均衡器将流量分配给Deployment中的Pod。
apiVersion: v1kind: Servicemetadata: name: nginx-servicespec: selector: app: nginx ports: - protocol: TCP port: 80 targetPort: 80 type: LoadBalancer
在上面的示例中,我们创建了一个名为nginx-service的Service对象,它将负责将流量分配给Deployment中的Pod。我们将type属性设置为LoadBalancer,这将自动为Service对象创建一个外部负载均衡器。
我们可以通过kubectl命令检查Service对象的状态:
kubectl get service nginx-service
输出应该类似于:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGEnginx-service LoadBalancer 10.0.111.157 203.0.113.10 80:30549/TCP 10s
上面的输出显示了Service对象的一些基本信息,包括CLUSTER-IP、EXTERNAL-IP和端口信息。
现在,我们可以使用EXTERNAL-IP和端口信息来访问我们的应用程序。但在我们开始访问应用程序之前,我们需要确保它已准备好接收流量。我们可以使用kubectl describe命令来检查Pod的状态:
kubectl describe pod
输出应该类似于:
Name: nginx-deployment-7d6ff77df6-f7m6kNamespace: defaultPriority: 0Node: minikube/192.168.99.107Start Time: Mon, 31 May 2021 16:10:53 +0300Labels: app=nginx pod-template-hash=7d6ff77df6Annotations: Status: RunningIP: 172.17.0.4IPs: Controlled By: ReplicaSet/nginx-deployment-7d6ff77df6Containers: nginx-container: Container ID: docker://3d7df1c0d93fc7e97467a35c2e82d26134b6bfbca6f9cb6d82e57e65dcb61990 Image: nginx Image ID: docker-pullable://nginx@sha256:95202e0d007bbd2edcad2b8eae1d2e6966efadfca6b7c6f9e57d71d06ef42b6f Port: 80/TCP Host Port: 0/TCP State: Running Started: Mon, 31 May 2021 16:11:05 +0300 Ready: False Restart Count: 0 Readiness: http-get http://:80/ delay=0s timeout=1s period=10s #success=1 #failure=3 Environment: Mounts: /var/run/secrets/kubernetes.io/serviceaccount from kube-api-access-vh2lm (ro)Conditions: Type Status Initialized True Ready False ContainersReady False PodScheduled True Volumes: kube-api-access-vh2lm: Type: Projected (a volume that contains injected data from multiple sources) TokenExpirationSeconds: 3607 ConfigMapName: kube-root-ca.crt ConfigMapOptional: DownwardAPI: trueQoS Class: BestEffortNode-Selectors: Tolerations: node.kubernetes.io/not-ready:NoExecute op=Exists for 300s node.kubernetes.io/unreachable:NoExecute op=Exists for 300sEvents: Type Reason Age From Message ---- ------ ---- ---- ------- Normal Scheduled 47s default-scheduler Successfully assigned default/nginx-deployment-7d6ff77df6-f7m6k to minikube Normal Pulled 45s kubelet Container image "nginx" already present on machine Normal Created 45s kubelet Created container nginx-container Normal Started 45s kubelet Started container nginx-container
输出显示了Pod中的nginx容器的状态。我们可以看到,容器的Readiness状态为False,这意味着它还没有准备好接收流量。我们还可以看到,容器的Readiness状态为False,这意味着它还没有准备好接收流量。我们还可以看到Readiness探针的详细信息,它会定期调用容器的/healthz端点以检查容器是否已准备好接收流量。
在这种情况下,我们的Readiness探针定义了一个HTTP GET请求,它将在容器的80端口上调用/healthz端点。如果该请求成功,则容器被认为是“就绪”的。
现在我们需要添加一个就绪探针来确保容器已准备好接收流量。在Kubernetes中,我们可以使用以下方式定义就绪探针:
HTTP GET探针:向容器发送一个HTTP GET请求,以检查容器是否已准备好接收流量。TCP Socket探针:尝试连接到容器的指定端口,以检查容器是否已准备好接收流量。Exec探针:在容器中执行指定的命令,并检查命令的退出状态以确定容器是否已准备好接收流量。在本例中,我们将使用HTTP GET探针。下面是一个包含就绪探针的更新后的Pod定义:
apiVersion: v1kind: Podmetadata: name: nginx labels: app: nginxspec: containers: - name: nginx image: nginx ports: - containerPort: 80 readinessProbe: httpGet: path: /healthz port: 80 initialDelaySeconds: 5 periodSeconds: 10
在这个更新的Pod定义中,我们添加了一个名为readinessProbe的字段,并在其中定义了HTTP GET探针。探针将在容器的80端口上调用/healthz端点,并在初始延迟5秒后每10秒执行一次。
现在,我们使用kubectl apply命令将更新的Pod定义应用于Kubernetes集群:
kubectl apply -f pod.yaml
如果我们再次运行kubectl describe pod命令,我们应该看到容器的Readiness状态已更改为True:
Name: nginxNamespace: defaultPriority: 0Node: minikube/192.168.99.107Start Time: Mon, 31 May 2021 16:10:53 +0300Labels: app=nginxAnnotations: Status: RunningIP: 172.17.0.4IPs: Controlled By: Containers: nginx: Container ID: docker://d96f8e1536c5feca2d79bfb13aebc5e47e5a6c5dd5d5b68a904a8110e32fbaec Image: nginx Image ID: docker-pullable://nginx@sha256:95202e0d007bbd2edcad2b8eae1d2e6966efadfca6bf772bd0eeb695c2d17c5b Port: 80/TCP Host Port: 0/TCP State: Running Started: Mon, 31 May 2021 16:11:04 +0300 Ready: True Restart Count: 0 Readiness: http-get http://:80/healthz delay=5s timeout=1s period=10s #success=1 #failure=3 Environment: Mounts: /var/run/secrets/kubernetes.io/serviceaccount from default-token-x4rrz (ro)Conditions: Type Status Initialized True Ready True ContainersReady True PodScheduled True Volumes: default-token-x4rrz: Type: Secret (a volume populated by a Secret) SecretName: default-token-x4rrz Optional: falseQoS Class: BestEffortNode-Selectors: Tolerations: node.kubernetes.io/not-ready:NoExecute op=Exists for 300s node.kubernetes.io/unreachable:NoExecute op=Exists for 300sEvents:
现在我们可以确认容器已经准备好接收流量,Readiness探针定期调用/healthz端点以确保容器仍然是就绪的。
-
世界最资讯丨kubernetes就绪探针使用
腾讯云 2023-04-29
-
今日热文:干粉灭火器分为哪几种型号_干粉灭火器分几种型号
互联网 2023-04-29
-
当前焦点!解难题、送温暖,济宁干休所开展“十进所、八上门”主题实践活动
中国山东网 2023-04-29
-
新沂市气象台发布大风蓝色预警[Ⅳ级/一般] 【2023-04-29】_世界短讯
九派观天下 2023-04-29
-
荷兰阿斯麦公司CEO:进入中国市场“是绝对必要的”
环球网 2023-04-29
-
克莱:我们没时间垂头丧气 我仍相信我们绝对能赢抢七
直播吧 2023-04-29
-
龙胜:五一游龙脊 壮美梯田待客来|焦点短讯
桂林龙胜 2023-04-29
-
2023年4月29日今天1美金兑换多少新币 天天新资讯
腾赚网 2023-04-29
-
环球即时:酒店民宿频见恶意违约 乱局如何破解?
新华社 2023-04-29
-
三未信安:4月28日融资买入1003.37万元,融资融券余额8496.35万元 今头条
证券之星 2023-04-29
-
世界最资讯丨kubernetes就绪探针使用
腾讯云 2023-04-29
-
今日热文:干粉灭火器分为哪几种型号_干粉灭火器分几种型号
互联网 2023-04-29
-
当前焦点!解难题、送温暖,济宁干休所开展“十进所、八上门”主题实践活动
中国山东网 2023-04-29
-
新沂市气象台发布大风蓝色预警[Ⅳ级/一般] 【2023-04-29】_世界短讯
九派观天下 2023-04-29
-
荷兰阿斯麦公司CEO:进入中国市场“是绝对必要的”
环球网 2023-04-29
-
克莱:我们没时间垂头丧气 我仍相信我们绝对能赢抢七
直播吧 2023-04-29
-
龙胜:五一游龙脊 壮美梯田待客来|焦点短讯
桂林龙胜 2023-04-29
-
2023年4月29日今天1美金兑换多少新币 天天新资讯
腾赚网 2023-04-29
-
环球即时:酒店民宿频见恶意违约 乱局如何破解?
新华社 2023-04-29
-
三未信安:4月28日融资买入1003.37万元,融资融券余额8496.35万元 今头条
证券之星 2023-04-29
-
保障性租赁住房REITs呈现高出租率,这种情况可持续吗?
每日经济新闻 2023-04-29
-
正邦科技(002157.SZ)发一季度业绩,净亏损11.79亿元
金融界 2023-04-29
-
天天微速讯:网络个人资料被泄露 我们应该如何处理
叶紫网 2023-04-29
-
上海贝岭(600171):4月28日北向资金增持31.05万股 天天速看料
证券之星 2023-04-29
-
佳木斯到哈尔滨火车时刻表查询_佳木斯到哈尔滨 世界观天下
互联网 2023-04-29
-
【新要闻】广西壮族自治区百色市2023-04-29 00:41发布雷电黄色预警
互联网 2023-04-29
-
本周盘点(4.24-4.28):竞业达周涨1.65%,主力资金合计净流出1111.90万元 全球信息
证券之星 2023-04-28
-
邮储银行开展“乡村加邮购车季”活动|全球新视野
凯迪网 2023-04-28
-
山推股份去年净利润6.32亿元 同比增长288.55%
同花顺财经 2023-04-28
-
全球看热讯:外贸进出口展现较强韧性 进口物流总额同比增长11.9%
西部网 2023-04-28
-
世界关注:明志科技:4月26日朱伟岸、陆高春增持公司股份合计26.21万股
证券之星 2023-04-28
-
【天天报资讯】高能电玩节:休闲竞技乱斗《钻头派对》新内容抢先看!
官方 2023-04-28
-
4-1到5-3!斯诺克世锦赛战报:斯佳辉领先布雷切尔,轰出两杆破百 动态
讲体育的哒哒君来了 2023-04-28
-
世界报道:高德上新手机弯道会车预警 可智能提示前方对向来车
懂车帝 2023-04-28
-
腾讯清仓?华谊兄弟去年净亏近10亿元,一季度营收增七成 全球今亮点
澎湃新闻 2023-04-28
-
天天视讯!社保基金一季度都买了啥?增持121只股 保险、AIGC概念受青睐(附名单)
21财经 2023-04-28
-
2023哪些人可以申请连云港籍优秀学子奖学金?附奖励标准|焦点滚动
互联网 2023-04-28
-
铁路等部门全力保障“五一”小长假出行高峰|天天热资讯
新华网 2023-04-28
-
工信部:一季度我国规模以上互联网企业实现利润总额282.8亿元,同比增长55.2%
智通财经 2023-04-28
-
2023年5月11日新股追踪:三联锻造等4只申购
南方财富网 2023-04-28