k8s常用命令
admin
2023-02-26 12:41:44
0

相关服务及用途

节点名称 服务名称 用途
管理节点 kubctl-apiserver 提供HTTP Rest统一接口服务,处理和验证REST请求和更新etcd中API对象的状态
管理节点 kubectl-controller-manager 资源控制管理同步
管理节点 kube-scheduler 负责资源调度(调度Pod)
工作节点 kubelet 管理Pod的生命周期,创建、启停等任务
工作节点 kube-proxy 负责网络通信及负载均衡

### 1.重启服务

kubectl patch deployment app名称 -p {\"spec\":{\"template\":{\"metadata\":{\"labels\":{\"date\":\"date +'%s'\"}}}}} -n kube-system


### 2.重新分配pod数量

kubectl scale deployment kubernetes-dashboard --replicas=1 -n kube-system

### 3.查看部署应用

kubectl get deploy -n kube-system


### 4.获得容器前一次运行的日志内容

kubectl logs --previous
kubectl logs --previous l7-lb-controller-74c67fb85d-5b5cg -n kube-system


### 5.查看描述

kubectl describe svc kubernetes-dashboard -n kube-system
kubectl describe pod kubernetes-dashboard -n kube-system


### 6.查看pod部署节点及IP

kubectl get pods -n kube-system -o wide


### 7.查看集群中服务

kubectl get services --all-namespaces
kubectl get svc kubernetes-dashboard -n kube-system


### 8.查看暴露端口

kubectl get endpoints -n kube-system kubernetes-dashboard
kubectl get ep -n kube-system kubernetes-dashboard


## 9.标签管理

添加标签

kubectl label node 192.168.61.66 nodetype=node --overwrite
lsmod | grep ip_vs

查看标签

kubectl get node --show-labels -n kube-system
kubectl get pods --show-labels kube-sytem
kubectl get pod --show-labels kubernetes-dashboard-6845889d64-25f9x -n kube-system


### 10.查看svc/pod描述

kubectl describe 类型 资源名称 命名空间
kubectl describe svc kubernetes-dashboard -n kube-system
kubectl describe pod kubernetes-dashboard -n kube-system

### 11.查询日志

检查某种Pod的日志(标准输出)

kubectl logs -f pod名称 -n kube-system

在容器内执行命令

kubectl exec -ti pod名称 /bin/bash -n kube-system


### 12.以yaml/json方式显示pod信息

kubectl get deployment -o yaml kubernetes-dashboard -n kube-system
kubectl get daemonset -o yaml -n kube-system calico-node
kubectl get svc -o json pod名称 -n kube-system


### 13.显示所有的服务

kubectl get deployments -n kube-system
kubectl get daemonsets -n kube-system


### 14.创建命名空间

通过命令创建

kubectl create namespace new-namespace

通过文件创建

cat > my-namespace.yaml << EOF
apiVersion: v1
kind: Namespace
metadata:
name: new-namespace
EOF
kubectl create -f ./my-namespace.yaml

删除命令空间

kubectl delete namespaces new-namespace

删除一个namespace会自动删除所有属于该namespace的资源。

default 和 kube-system 命名空间不可删除。


### 15.创建/查看 Deployment 记录版本号

kubectl create -f nginx-deployment.yaml --record


### 16.实现水平扩展或收缩

kubectl scale deployment kubernetes-dashboard --replicas=2 -n kube-system

重新分配pod数量

kubectl scale deployment kubernetes-dashboard --replicas=1 -n kube-system


### 17.版本回退

查看回退状态

kubectl rollout status deployment/kubernetes-dashboard -n kube-system

查看升级历史记录

kubectl rollout history deployment/kubernetes-dashboard -n kube-system

查看单个revision的详细信息

kubectl rollout history deployment/kubernetes-dashboard --revision=1 -n kube-system

回滚到上一个版本

kubectl rollout undo deployment/kubernetes-dashboard -n kube-system

指定回滚某个历史版本

kubectl rollout undo deployment/kubernetes-dashboard --to-revision=1 -n kube-system


### 18.自动扩展

集群支持 horizontal pod autoscaling,可以为Deployment设置自动扩展

kubectl autoscale deployment kubernetes-dashboard --min=1 --max=5 --cpu-percent=80 -n kube-system

查看hap状态

kubectl get hpa kubernetes-dashboard -n kube-system

查看hpa详细状态

kubectl describe hpa kubernetes-dashboard -n kube-system

删除hpa

kubectl delete hpa kubernetes-dashboard -n kube-system


### 19.更新Deployment镜像

kubectl set image deployment kubernetes-dashboard nginx=nginx:1.9.1

### 20.编辑 Deployment pod配置

kubectl edit deployment kubernetes-dashboard -n kube-system


### 21.升级资源

暂停状态下执行

kubectl rollout pause deployment kubernetes-dashboard -n kube-system
kubectl set image deploy kubernetes-dashboard nginx=nginx:1.9.1

更新升级资源

kubectl set resources deployment kubernetes-dashboard -c=kubernetes-dashboard --limits=cpu=200m,memory=512Mi -n kube-system

恢复

kubectl rollout resume deploy kubernetes-dashboard -n kube-system


### 22.查看CIDR划分
kubectl get nodes -o json | jq '.items[] | .spec'

## 23.授权管理

查看授权node节点

kubectl get certificatesigningrequests
kubectl get csr

添加新工作节点

kubectl get csr|grep 'Pending' | awk 'NR>0{print $1}'| xargs kubectl certificate approve

批量授权认证

for i in kubectl get csr|grep -v NAME|awk '{print $1}';do kubectl certificate approve $i;done
kubectl get nodes

拒绝授权

kubectl certificate deny node-csr-AzAMd7KYm57dUkiD-aM3POpS_N37bXCyHeI_B-llyQM

批量拒绝授权

for i in kubectl get csr|grep -v NAME|awk '{print $1}';do kubectl certificate deny $i;done

删除信任csr节点

kubectl delete csr node-csr-AzAMd7KYm57dUkiD-aM3POpS_N37bXCyHeI_B-llyQM

批量删除授权

for i in kubectl get csr|grep -v NAME|awk '{print $1}';do kubectl delete csr $i;done


### 24.集群信息查看

下载 kubeadm

curl -sSL https://dl.k8s.io/release/v1.11.2/bin/linux/amd64/kubeadm > /usr/bin/kubeadm

查看集群访问连接

kubectl cluster-info

查看权限

kubectl describe clusterrole cluster-admin -n kube-system

查看kubectl版本

kubectl version

查看支持api版本

kubectl api-version

查看当前kubectl配置

kubectl config view

查看集群状态

kubectl get componentstatuses
kubectl get rs

查看集群节点

kubectl get nodes

查看命名空间

kubectl get namespaces

Node状态维护

每个Node都包括以下状态信息
地址:包括hostname、外网IP和内网IP
条件(Condition):包括OutOfDisk、Ready、MemoryPressure和DiskPressure
容量(Capacity):Node上的可用资源,包括CPU、内存和Pod总数
基本信息(Info):包括内核版本、容器引擎版本、OS类型等

维护状态/取消维护模式

kubectl cordon NodeName
kubectl uncordon NodeName

相关内容

热门资讯

终于了解“快乐打筒子.怎么装挂... 有 亲,根据资深记者爆料快乐打筒子是可以开挂的,确实有挂(咨询软件无需打...
玩家最新攻略“琼戏互娱.究竟有... 您好:琼戏互娱这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
终于了解“新九方炸金花.开挂器... 有 亲,根据资深记者爆料新九方炸金花是可以开挂的,确实有挂(咨询软件无需...
最新引进“新蓝鲸.到底有挂吗?... 有 亲,根据资深记者爆料新蓝鲸是可以开挂的,确实有挂(咨询软件无需打开直...
玩家攻略科普“中至上饶麻将.真... 您好:中至上饶麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款...
【今日要闻】“花城牌舍.可以开... 有 亲,根据资深记者爆料花城牌舍是可以开挂的,确实有挂(咨询软件无需打开...
乌代表团与美欧举行系列会议,美... 当地时间12月21日,美国总统特使威特科夫表示,过去三天,乌克兰代表团在美国佛罗里达州与美国和欧洲伙...
终于懂了“新青鸟牛牛.怎么装挂... 您好:新青鸟牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
今日重磅消息“圣盛宜昌花牌.真... 今日重磅消息“圣盛宜昌花牌.真的有挂吗?”其实是有挂您好,圣盛宜昌花牌这个游戏其实有挂的,确实是有挂...
开发者破1000万,华为鸿蒙迈... 据心声社区公众号 12 月 19 日分享,鸿蒙迈过了生死线 —— 搭载 HarmonyOS 5、Ha...