K8S 常用命令全解析:高效管理容器化集群
创作时间:
作者:
@小白创作中心
K8S 常用命令全解析:高效管理容器化集群
引用
CSDN
1.
https://m.blog.csdn.net/2401_86610558/article/details/144620942
K8S 常用命令全解析:高效管理容器化集群
一、引言
Kubernetes(K8S)作为强大的容器编排平台,其丰富的命令行工具(kubectl)为用户提供了便捷的方式来管理集群中的各种资源。熟练掌握 K8S 常用命令对于开发人员和运维人员至关重要,能够有效提高容器化应用的部署、监控与维护效率。本文将详细介绍一些 K8S 常用命令及其使用案例。
二、基础资源操作命令
(一)kubectl create
功能:用于创建 K8S 资源对象,如 Pod、Deployment、Service 等。
使用案例:
- 创建一个简单的 Nginx Deployment。首先编写一个
nginx-deployment.yaml
文件:
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
spec:
replicas: 3
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:latest
ports:
- containerPort: 80
- 然后使用命令创建:
kubectl create -f nginx-deployment.yaml
- 此命令会在集群中创建一个名为
nginx-deployment
的 Deployment,包含 3 个运行 Nginx 容器的副本。
(二)kubectl get
功能:获取集群中各种资源对象的信息。
使用案例:
- 获取所有的 Deployment 信息:
kubectl get deployments
- 输出会显示 Deployment 的名称、就绪副本数、可用副本数、创建时间等信息,例如:
NAME READY UP-TO-DATE AVAILABLE AGE
nginx-deployment 3/3 3 3 10m
- 获取所有的 Pod 信息:
kubectl get pods
- 可以看到每个 Pod 的名称、所在节点、状态、重启次数等,如:
NAME READY STATUS RESTARTS AGE
nginx-deployment-5f7d9849f8-4h2g9 1/1 Running 0 10m
nginx-deployment-5f7d9849f8-6z7t8 1/1 Running 0 10m
nginx-deployment-5f7d9849f8-9v5b6 1/1 Running 0 10m
(三)kubectl describe
功能:查看资源对象的详细信息,包括资源的状态、事件、关联的其他资源等。
使用案例:
- 查看某个 Deployment 的详细信息:
kubectl describe deployment nginx-deployment
- 输出会包含该 Deployment 的详细配置信息,如选择器、副本数、更新策略等,以及相关的事件信息,例如:
Name: nginx-deployment
Namespace: default
CreationTimestamp: Fri, 20 Dec 2024 14:30:00 UTC
Labels: app=nginx
Annotations: deployment.kubernetes.io/revision: 1
Selector: app=nginx
Replicas: 3 desired | 3 updated | 3 total | 3 available | 0 unavailable
StrategyType: RollingUpdate
MinReadySeconds: 0
RollingUpdateStrategy: 25% max unavailable, 25% max surge
Pod Template:
Labels: app=nginx
Containers:
nginx:
Image: nginx:latest
Port: 80/TCP
Host Port: 0/TCP
Environment: <none>
Mounts: <none>
Volumes: <none>
Conditions:
Type Status Reason
---- ------ ------
Available True MinimumReplicasAvailable
Progressing True NewReplicaSetAvailable
OldReplicaSets: <none>
NewReplicaSet: nginx-deployment-5f7d9849f8 (3/3 replicas created)
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal ScalingReplicaSet 10m deployment-controller Scaled up replica set nginx-deployment-5f7d9849f8 to 3
(四)kubectl delete
功能:删除集群中的资源对象。
使用案例:
- 删除之前创建的
nginx-deployment
:
kubectl delete deployment nginx-deployment
- 执行后,该 Deployment 及其关联的 Pod 都会被删除。
三、资源伸缩与更新命令
(一)kubectl scale
功能:对资源对象进行伸缩,如调整 Deployment 的副本数。
使用案例:
- 将某个 Deployment 的副本数增加到 5:
kubectl scale deployment nginx-deployment --replicas 5
- 可以通过
kubectl get pods
看到新的 Pod 被创建,直到达到 5 个副本。
(二)kubectl set
功能:更新资源对象的某些属性,如更新 Deployment 中的容器镜像。
使用案例:
- 更新
nginx-deployment
中的 Nginx 镜像为nginx:1.21
:
kubectl set image deployment nginx-deployment nginx=nginx:1.21
- Kubernetes 会自动采用滚动更新的方式,逐个替换旧版本的容器,在更新过程中可以使用
kubectl rollout status deployment nginx-deployment
查看更新进度。
(三)kubectl rollout
功能:管理资源对象的滚动更新和回滚操作。
使用案例:
- 查看 Deployment 的更新状态:
kubectl rollout status deployment nginx-deployment
- 如果更新过程中出现问题,回滚到上一个版本:
kubectl rollout undo deployment nginx-deployment
四、网络与服务相关命令
(一)kubectl expose
功能:将一个资源对象(如 Deployment)暴露为一个 Service,以便在集群内部或外部访问。
使用案例:
- 将
nginx-deployment
暴露为一个 ClusterIP 类型的 Service:
kubectl expose deployment nginx-deployment --port 80 --targetPort 80 --type ClusterIP
- 这样就创建了一个名为
nginx-deployment
的 Service,集群内部其他资源可以通过该 Service 的 ClusterIP 访问 Nginx 服务。
(二)kubectl get services
功能:获取集群中 Service 的信息。
使用案例:
- 查看所有 Service 的信息:
kubectl get services
- 输出会显示 Service 的名称、类型、ClusterIP、端口等信息,例如:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
nginx-deployment ClusterIP 10.96.196.230 <none> 80/TCP 5m
五、集群与节点操作命令
(一)kubectl cluster-info
功能:查看集群的信息,如控制平面的地址等。
使用案例:
kubectl cluster-info
- 输出可能类似:
Kubernetes master is running at https://192.168.1.100:6443
CoreDNS is running at https://192.168.1.100:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
(二)kubectl get nodes
功能:获取集群中节点的信息。
使用案例:
kubectl get nodes
- 可以看到节点的名称、状态、角色、版本等信息,例如:
NAME STATUS ROLES AGE VERSION
node1 Ready <none> 1d v1.20.0
node2 Ready <none> 1d v1.20.0
(三)kubectl drain
功能:将节点设置为不可调度状态,并驱逐该节点上的 Pod,以便对节点进行维护或升级。
使用案例:
- 准备对
node1
进行维护,先将其设置为不可调度并驱逐 Pod:
kubectl drain node1
- 执行后,
node1
上的 Pod 会被迁移到其他可用节点,然后可以安全地对node1
进行操作,如升级操作系统或重启节点。操作完成后,使用kubectl uncordon node1
恢复节点的可调度状态。
六、总结
通过对这些 K8S 常用命令及其使用案例的学习,能够初步掌握在 Kubernetes 集群中进行资源管理、应用部署与更新、网络配置以及集群维护等操作的基本技能。在实际应用中,这些命令将是构建、管理和维护容器化应用平台的有力工具,随着对 K8S 深入学习和实践,还会接触到更多高级命令和用法,进一步提升容器编排与管理的能力。
热门推荐
黑洞的形成原理,事件视界是虫洞入口吗?如何靠近黑洞的奇点呢?
深入解析:大科技期刊影响因子及其重要性
如何阅读工程图纸:新制造商指南
NoSQL数据库与关系型数据库有何不同?
mAh是多少毫安?
年轻人结婚意愿不强:透视背后的经济、社会与心理因素
结婚意愿减弱,年轻人越来越不想结婚了现象解析
轮间差速器结构与原理
电焊一阵烟,伤人于无形
大腿肌肉强化训练,提升全身运动表现
腿部燃脂训练器介绍,9个HIIT高效燃脂动作
鼻甲肥大和鼻中隔偏曲的区别
石油是怎么生成的呢?
柏树移栽绝招
高等教育中的数据驱动决策
购买的商标买来就能用吗
缺陷检测中的数据标注工作如何进行
美国的银行类型:了解美国银行体系及其特点
手机转账无需手续费:掌握这些技巧,让你省钱又方便
年轻人手抖的健康锻炼
重磅丨第四代ALK靶向药NVL-655,最新临床试验数据公布
压敏胶块在热熔前后的粘性差别
从药物到手术,揭秘脊柱结核的全方位治疗方案
如何抓团队思想引领
科目一补考的预约流程是什么?有哪些需要注意的事项?
交流电功率详解:从基本概念到功率因数的提升方法
什么是离子色谱仪?
一篇文章让你了解什么是离子对色谱(IPC)
马应龙痔疮膏是否对孕妇和胎儿有影响
IATF 16949 全面解析:汽车行业质量管理体系的核心要点