本文主要整理了Kubernetes常用命令,给朋友们一个备忘录。
查看K8S的帮助命令
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
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
本篇完结!感谢你的阅读,欢迎点赞 关注 收藏 私信!!!
原文链接: www.mangod.top/articles/20…、mp.weixin.qq.com/s/szxN9bSFK…