偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

K8s pod刪除操作,你會(huì)了嗎?

運(yùn)維
k8s運(yùn)維過程中,pod異常情況下,需要我們?nèi)h除pod來恢復(fù)業(yè)務(wù),本文總結(jié)了pod幾種常見的刪除方法。

  • 常規(guī)刪除

直接根據(jù)pod名稱刪除是最常見的方式,刪除后如果pod使用deployment創(chuàng)建一般會(huì)自動(dòng)創(chuàng)建新的容器。

kubectl delete pods  deployment-ngx-8ff559dc9  -n kube-system
pod "deployment-ngx-8ff559dc9" deleted

還可以使用下面這些命令來刪除pod

通過pod.json文件中指定的資源類型和名稱刪除一個(gè)pod
$ kubectl delete -f ./pod.json
刪除所有名為"”baz""foo"的pod和service
$ kubectl delete pod,service baz foo
刪除所有帶有l(wèi)able name=myLabel的pod和service
$ kubectl delete pods,services -l name=myLabel
刪除UID為1234-56-7890-234234-456456的pod
$ kubectl delete pod 1234-56-7890-234234-456456
刪除所有的pod,用于機(jī)器異常狀況下的快速恢復(fù)
$ kubectl delete pods --all

直接刪除pod的方式,由于deployment資源定義了pod的副本數(shù)量,會(huì)將pod維持在期望的狀態(tài),如果想徹底刪除,則需要?jiǎng)h除對應(yīng)的deployment

kubectl delete deployment   name -n [namespace]   #加-n指定命令空間
  • 根據(jù)標(biāo)簽刪除

查看pod中的標(biāo)簽。

kubectl get pod --show-labels
NAME READY STATUS RESTARTS AGE LABELS
nginx1 1/1 Running 0 4h59m
nodejs-1 1/1 Running 0 5h7m env=Basic_version,versions=test
nodejs-2 1/1 Running 0 3h48m env=development_version,versions=Minor_upgrade

刪除帶有 versions=test 標(biāo)簽的pod,這種方法其實(shí)也是直接刪除pod,只是運(yùn)動(dòng)標(biāo)簽的功能快速刪除,前提是你使用了標(biāo)簽。

kubectl delete pod -l versions=testpod "
nodejs-1" deleted
  • 副本伸縮

生產(chǎn)環(huán)境中,經(jīng)常會(huì)根據(jù)業(yè)務(wù)量的變化來調(diào)整pod的副本個(gè)數(shù),也可以用這種方式來刪除pod,或者用作升級(jí)過程中關(guān)閉業(yè)務(wù)入口。

kubectl scale deploy/nginx-1 --replicas=0 -n [namespace]  #將副本個(gè)數(shù)縮為0

kubectl scale可以操作deployment副本伸縮,通過修改--replicas的數(shù)量來實(shí)現(xiàn)縮容和擴(kuò)容。

  • 強(qiáng)制刪除

Teminating是比較常見的pod狀態(tài),這種狀態(tài)一般是pod處于銷毀狀態(tài)但是并沒有正常刪除。

[root@k8s-master ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
deployment-ngx-8ff559dc9 0/1 Terminating 0 6m10s
deployment-ngx-8ff559dc9 0/1 Terminating 0 16m

遇到node宕機(jī)或者失聯(lián)太久可能就會(huì)導(dǎo)致pod一直處于Terminating狀態(tài),這時(shí)候使用kubectl delete不一定可以刪除,這種狀態(tài)下pod已經(jīng)確定已經(jīng)無法提供服務(wù)了。

kubectl delete pod  [pod name] --force --grace-period=0 -n [namespace]

Kubernetes中提供了grace-period參數(shù),在Pod刪除時(shí)此選項(xiàng)會(huì)起作用,會(huì)延遲一定時(shí)長才進(jìn)行刪除,缺省未設(shè)定的情況下會(huì)等待30s之后刪除,此處我們指定grace-period為0,表示立刻刪除pod。

為什么要延遲刪除? 判斷的標(biāo)準(zhǔn)是 DeletionGracePeriodSeconds 值是否為 0,不為零則是優(yōu)雅刪除,apiserver 不會(huì)立即將這個(gè)對象從etcd中刪除,否則直接刪除。對于Pod而言,默認(rèn) DeletionGracePeriodSeconds為30 秒,因此這里不會(huì)被立刻刪除掉,DeletionGracePeriodSeconds 設(shè)置為默認(rèn)值 30 秒。在刪除之前,很多容器化的應(yīng)用往往還有一些操作需要處理,而這些都需要一些時(shí)間。

  • etcd中刪除

先找到etcd的三個(gè)證書相關(guān)文件,在目錄 /etc/kubernetes/pki/etcd/ 下

證書位置查看

systemctl status etcd

執(zhí)行命令查找pod

ETCDCTL_API=3 etcdctl --endpoints=??https://ip:2379?? --cacert=/etc/kubernetes/pki/etcd/ca.pem --cert=/etc/kubernetes/pki/etcd/etcd-client.pem --key=/etc/kubernetes/pki/etcd/etcd-client-key.pem get /registry/pod --prefix --keys-only | grep {pod-name}

執(zhí)行命令刪除pod

ETCDCTL_API=3 etcdctl --endpoints=??https://ip:2379?? --cacert=/etc/kubernetes/pki/etcd/ca.pem --cert=/etc/kubernetes/pki/etcd/etcd-client.pem --key=/etc/kubernetes/pki/etcd/etcd-client-key.pem del /registry/pods/default/{pod-name}
責(zé)任編輯:龐桂玉 來源: 運(yùn)維之美
相關(guān)推薦

2024-05-10 08:00:48

K8soperatorGitHub

2024-09-11 08:02:27

k8sgitlab升級(jí)

2023-07-04 07:30:03

容器Pod組件

2025-01-03 09:07:51

2019-05-20 16:30:36

PythonMySQL存儲(chǔ)

2024-12-05 10:00:54

K8s參數(shù)Pod

2022-06-01 09:38:36

KubernetesPod容器

2024-03-18 15:44:48

K8S故障運(yùn)維

2022-04-22 13:32:01

K8s容器引擎架構(gòu)

2024-02-27 08:39:19

RustJSON字符串

2021-12-01 07:19:44

C# Npoi Excel

2018-04-26 16:35:44

PythonMySQL存儲(chǔ)

2022-10-10 12:54:00

Flink運(yùn)維

2023-11-06 01:17:25

主機(jī)容器選項(xiàng)

2024-01-19 08:25:38

死鎖Java通信

2022-04-01 08:23:17

InputstreString字符串

2023-07-26 13:11:21

ChatGPT平臺(tái)工具

2023-01-10 08:43:15

定義DDD架構(gòu)

2024-02-04 00:00:00

Effect數(shù)據(jù)組件

2023-08-01 12:51:18

WebGPT機(jī)器學(xué)習(xí)模型
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)