5 分钟上手 K8s:精简实用的 kubectl 命令速查宝典!

文摘   2024-11-08 10:05   中国香港  

对于刚开始学习 Kubernetes 的人来说,理解和掌握 kubectl 命令是入门的第一步。kubectl 是 Kubernetes 的命令行工具,用于管理 Kubernetes 集群中的资源。在这篇文章中,我们将总结一些最常用的 kubectl 命令,通过简明的介绍和示例,让你在 5 分钟内快速上手 Kubernetes,优雅地开始使用 K8s!

1. 配置与基本信息查询

1.1 设置 Kubernetes 上下文

kubectl 依赖配置文件来连接和管理集群。默认配置文件位于 ~/.kube/config

# 查看当前上下文
kubectl config current-context

# 设置新的上下文(例如:切换到生产环境)
kubectl config use-context <context-name>

通过正确的上下文配置,你可以轻松切换到不同的集群环境,如测试集群、生产集群等。

1.2 获取节点信息

在 Kubernetes 中,节点是运行 Pods 的物理或虚拟机。以下命令可以帮助你查看集群中所有节点的状态。

# 查看所有节点的信息
kubectl get nodes

# 查看节点详细信息
kubectl describe node <node-name>

2. 资源查看与管理

2.1 查看 Pods

Pod 是 Kubernetes 中的最小部署单元,通常包含一个或多个容器。

# 查看所有命名空间中的 Pods
kubectl get pods --all-namespaces

# 查看特定命名空间中的 Pods
kubectl get pods -n <namespace>

# 查看 Pod 的详细信息
kubectl describe pod <pod-name>

2.2 部署(Deployment)管理

Deployment 是用于管理 Pod 的 Kubernetes 资源,支持滚动更新和回滚。

# 查看所有部署
kubectl get deployments

# 查看特定命名空间中的部署
kubectl get deployments -n <namespace>

# 部署一个应用(例如 Nginx)
kubectl create deployment nginx --image=nginx

# 更新 Deployment 的镜像版本
kubectl set image deployment/nginx nginx=nginx:1.16.1

# 删除 Deployment
kubectl delete deployment nginx

2.3 服务(Service)管理

Service 是 Kubernetes 中的网络资源,用于暴露一组 Pods,并提供负载均衡。

# 查看所有服务
kubectl get services

# 暴露 Deployment 创建一个 Service(例如 NodePort 类型)
kubectl expose deployment nginx --port=80 --type=NodePort

# 查看特定 Service 的详细信息
kubectl describe service nginx

# 删除 Service
kubectl delete service nginx

3. 日志和调试

3.1 查看 Pod 日志

在开发和调试过程中,查看 Pod 的日志非常重要。可以使用 kubectl logs 命令来获取容器日志。

# 查看单个容器的日志
kubectl logs <pod-name>

# 如果 Pod 中有多个容器,指定容器名查看日志
kubectl logs <pod-name> -c <container-name>

# 实时流式查看日志
kubectl logs -f <pod-name>

3.2 进入 Pod 内部执行命令

在调试时,有时需要进入 Pod 内部执行命令,可以使用 kubectl exec 进入容器。

# 进入 Pod 内部
kubectl exec -it <pod-name> -- /bin/sh

# 运行一个命令,例如查看 Pod 内部的文件
kubectl exec <pod-name> -- cat /etc/hostname

3.3 查看集群事件

Kubernetes 会记录集群中发生的事件,例如 Pod 的创建、调度失败等,这对于故障排查非常有用。

# 查看所有事件
kubectl get events

# 按时间排序事件
kubectl get events --sort-by='.metadata.creationTimestamp'

4. 配置管理

4.1 创建与管理 ConfigMap

ConfigMap 用于存储配置信息,可以将它们加载到容器中作为环境变量或配置文件。

# 从键值对创建 ConfigMap
kubectl create configmap my-config --from-literal=key1=value1 --from-literal=key2=value2

# 查看所有 ConfigMap
kubectl get configmaps

# 查看 ConfigMap 详细信息
kubectl describe configmap my-config

4.2 创建与管理 Secret

Secret 用于存储敏感信息,例如密码、OAuth 令牌等。

# 创建 Secret
kubectl create secret generic my-secret --from-literal=password=my-password

# 查看所有 Secret
kubectl get secrets

# 查看 Secret 详细信息
kubectl describe secret my-secret

5. 资源扩展和更新

5.1 扩展 Deployment

当流量增加时,可以轻松扩展应用的副本数以满足需求。

# 扩展 Deployment 的副本数
kubectl scale deployment nginx --replicas=3

5.2 滚动更新

滚动更新允许你在不中断服务的情况下更新应用。

# 更新 Deployment 的镜像版本
kubectl set image deployment/nginx nginx=nginx:1.17.0

# 查看更新进度
kubectl rollout status deployment/nginx

5.3 回滚更新

如果新的 Deployment 版本出现问题,可以快速回滚。

# 查看更新历史
kubectl rollout history deployment/nginx

# 回滚到上一个版本
kubectl rollout undo deployment/nginx

6. 清理资源

最后,不再使用的资源可以通过以下命令删除,以释放集群资源。

# 删除 Pod
kubectl delete pod <pod-name>

# 删除 Deployment
kubectl delete deployment nginx

# 删除 Service
kubectl delete service nginx

结语

以上就是 Kubernetes 中常用 kubectl 命令的总结。这些命令涵盖了日常的集群管理和应用操作,如查看资源、部署应用、调试和更新等。通过这些命令,你可以快速上手 Kubernetes 的基本操作,优雅地管理 Kubernetes 集群中的应用。希望这篇文章能帮助你快速熟悉 Kubernetes!

KubeSphere v4 应用商店配置指南

2024-11-01

KubeSphere v4 安装指南

2024-10-16

KubeSphere v4 大解析:揭秘您最关心的 12 大热点问题

2024-10-18

关于 KubeSphere

KubeSphere (https://kubesphere.io)是在 Kubernetes 之上构建的开源容器平台,提供全栈的 IT 自动化运维的能力,简化企业的 DevOps 工作流。

KubeSphere 已被 Aqara 智能家居、本来生活、东方通信、微宏科技、东软、华云、新浪、三一重工、华夏银行、四川航空、国药集团、微众银行、紫金保险、去哪儿网、中通、中国人民银行、中国银行、中国人保寿险、中国太平保险、中国移动、中国联通、中国电信、天翼云、中移金科、Radore、ZaloPay 等海内外数万家企业采用。KubeSphere 提供了开发者友好的向导式操作界面和丰富的企业级功能,包括 Kubernetes 多云与多集群管理、DevOps (CI/CD)、应用生命周期管理、边缘计算、微服务治理 (Service Mesh)、多租户管理、可观测性、存储与网络管理、GPU support 等功能,帮助企业快速构建一个强大和功能丰富的容器云平台。


 ✨ GitHub:https://github.com/kubesphere
 💻 官网(中国站):https://kubesphere.io/zh
 🙋 论坛https://ask.kubesphere.io/forum/
 👨‍💻‍ 微信群:请搜索添加群助手微信号 kubesphere
 🔗 企业服务https://kubesphere.cloud
 🌐 企业官网https://kubesphere.com.cn


文章转载自KubeSphere云原生点击这里阅读原文了解更多

CNCF概况(幻灯片)

扫描二维码联系我们!




CNCF (Cloud Native Computing Foundation)成立于2015年12月,隶属于Linux  Foundation,是非营利性组织。 

CNCF云原生计算基金会)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。我们通过将最前沿的模式民主化,让这些创新为大众所用。请关注CNCF微信公众号。

CNCF
云原生计算基金会(CNCF)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。我们通过将最前沿的模式民主化,让这些创新为大众所用。
 最新文章