Kubernetes常用命令 K8S


---切换被操作的集群

默认情况下会在.kube目录下的config文件里的证书去操作K8S集群。如果碰到需要切换访问别的K8S集群的场景,可以使用kubectl --kubeconfig xxxxxx去指定某个证书文件,比如:

kubectl --kubeconfig (xxxx.json | xxxxconfig) get node


---创建资源对象

kubectl apply -f xxx.yaml


---查找资源对象

# 查到node

kubectl get node

# 查到namespace

kubectl get ns

# 查找service

kubectl get svc -n demo

# 查找部署资源

kubectl get deployment -n demo

# 查找pod

kubectl get pods -n demo

# 查找pod,展示更多信息

kubectl get pods -n demo -o wide


---描述资源对象

describe命令非常重要,当你部署资源出现问题时,可以通过这个命令去查看原因。

# 描述pod

kubectl describe pods webapp -n demo

# 描述node

kubectl describe node k8s-worker-2

# 描述ingress

kubectl describe ingress xxxxxx-ingress -n demo

# 描述service

kubectl describe svc web-service -n demo


---伸缩资源

扩展副本数到4:

kubectl scale --replicas=4 deployment/xxxxxx -n demo

重新缩减副本数到2:

kubectl scale --replicas=2 deployment/xxxxxx -n demo

根据情况自动缩放:

kubectl autoscale deployment xxxxxx --min=1 --max=4 -n demo
kubectl autoscale deployment ehome-cloud-server --min=1 --max=3 -n test1 --cpu-percent=80

获取水平自动缩放器

kubectl get hpa -n test1

删除水平自动缩放器

kubectl delete hpa ehome-cloud-server -n test1


---操作label

label是集群内部用来查找和筛选的标签,非常重要。

kubectl label node k8s-worker-3 app=backend
kubectl label node k8s-worker-3 app-
kubectl get nodes --show-labels
kubectl get nodes k8s-worker-3 --show-labels
kubectl label pods xxxxxx addlabel=addlabelval -n demo


----添加污点

# 添加污点

kubectl taint nodes node01 key=value:effect

# 删除污点

kubectl taint nodes node01 key[:effect]-


---删除资源

kubectl delete -f xxx.yaml
kubectl delete pod xxx -n demo


---查看日志

kubectl logs -f xxxxxx-9d8695998-s9cwk -n demo
kubectl logs xxxxxx-9d8695998-s9cwk -n demo


---进入容器内部

kubectl exec -it webapp -n demo -- /bin/sh


---查看使用资源的情况

kubectl top pod
kubectl top node


签名:这个人很懒,什么也没有留下!
最新回复 (0)
返回