K8S学习之kubectl常用命令总结
- Pod相关命令
- NameSpace相关命令
- DaemonSet相关命令
- 基于yaml配置文件操作资源
- 进阶命令
- 参考链接
Pod相关命令
# 获取pod信息,默认是default名称空间
kubectl get pod
# 获取pod信息,默认是default名称空间,并查看附加信息【如:pod的IP及在哪个节点运行】
kubectl get pod -o wide
# 获取指定名称空间的pod
kubectl get pod -n kube-system
# 获取指定名称空间中的指定pod
kubectl get pod -n kube-system podName
# 获取所有名称空间的pod
kubectl get pod -A
# 查看pod的详细信息,以yaml格式或json格式显示
kubectl get pods -o yaml
kubectl get pods -o json
# 查看pod的标签信息
kubectl get pod -A --show-labels
# 根据Selector(label query)来查询pod
kubectl get pod -A --selector="k8s-app=kube-dns"
# 查看运行pod的环境变量
kubectl exec podName env
# 查看指定pod的日志
kubectl logs -f --tail 500 -n kube-system kube-apiserver-k8s-master
# 查看某个docker日志
kubectl logs ${podName} -c ${dockerName}
# 查看pod的描述信息
kubectl describe pod podName
kubectl describe pod -n kube-system kube-apiserver-k8s-master
# 查看pod的资源使用情况
# 需要heapster 或metrics-server支持
kubectl top pod
# 删除指定的pod
kubectl delete pod podName
# 删除指定名称空间的指定pod
kubectl delete pod -n test podName
# 指定标签删除pod
kubectl delete pod -l aaa=bbb
# 删除命名空间的所有pod但保留命名空间
kubectl delete pod --all -n ${nameSpaceName}
# 强制删除POD
kubectl delete pod PODNAME --force --grace-period=0
# 强制删除default namespace下的pod名为pod-to-be-deleted-0
ETCDCTL_API=3 etcdctl del /registry/pods/default/pod-to-be-deleted-0
# kubectl exec:进入pod启动的容器
kubectl exec -it podName -n nsName /bin/sh #进入容器
kubectl exec -it podName -n nsName /bin/bash #进入容器
kubectl label pod podName -n nsName role-name=test #为指定pod添加标签
kubectl label pod podName -n nsName role-name=dev --overwrite #修改lable标签值
kubectl label pod podName -n nsName role-name- #删除lable标签
NameSpace相关命令
# 创建test名称空间
kubectl create namespace test
# 查看命名空间列表
kubectl get ns
# 删除命名空间
kubectl delete ns ${nameSpaceName}
# 查看命名空间列表
kubectl get ns
# 删除命名空间的几乎所有资源
kubectl delete all --all -n ${nameSpaceName}
DaemonSet相关命令
# 创建DaemonSet(默认命名空间)
kubectl create daemonset demo1-mvcone --image=192.168.0.101:10080/eshop/demo1.mvcone:v1.0.1
# 创建DaemonSet(创建到指定命名空间)
kubectl create daemonset demo1-mvcone --image=192.168.0.101:10080/eshop/demo1.mvcone:v1.0.1 -n kube-public
# 查看默认命名空间下的DaemonSet
kubectl get daemonset -o wide
# 查看指定命名空间下的DaemonSet
kubectl get daemonset -n kube-public -o wide
# 查看详细 DaemonSet 信息
kubectl describe daemonset demo1-mvcone
# 监视 DaemonSet 回滚进度
kubectl rollout status daemonset demo1-mvcone
基于yaml配置文件操作资源
# 创建资源
kubectl create -f yaml配置文件名.yaml
# 修改已存在的资源(建议替代create命令)
kubectl apply -f yaml配置文件名.yaml
# 用yaml格式查看资源配置清单
kubectl get service demo1-mvcibe -o yaml #查看service
# 删除资源
kubectl delete -f yaml配置文件名.yaml
进阶命令
# kubectl label:添加label值
kubectl label nodes k8s-node01 zone=north #为指定节点添加标签
kubectl label nodes k8s-node01 zone- #为指定节点删除标签
# kubectl滚动升级; 通过 kubectl apply -f myapp-deployment-v1.yaml 启动deploy
kubectl apply -f myapp-deployment-v2.yaml #通过配置文件滚动升级
kubectl set image deploy/myapp-deployment myapp="registry.cn-beijing.aliyuncs.com/google_registry/myapp:v3" #通过命令滚动升级
kubectl rollout undo deploy/myapp-deployment 或者 kubectl rollout undo deploy myapp-deployment #pod回滚到前一个版本
kubectl rollout undo deploy/myapp-deployment --to-revision=2 #回滚到指定历史版本
# kubectl scale:动态伸缩
kubectl scale deploy myapp-deployment --replicas=5 # 动态伸缩
kubectl scale --replicas=8 -f myapp-deployment-v2.yaml #动态伸缩【根据资源类型和名称伸缩,其他配置「如:镜像版本不同」不生效】