本文主要整理了Kube.NETes常用命令,给朋友们一个备忘录。
kubectl --help
默认情况下会在.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是集群内部用来查找和筛选的标签,非常重要。
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