Kubernetes(K8S)命令指南

简介: Kubernetes(K8S)命令指南

本文提供了一份全面的Kubernetes(K8S)命令指南,旨在帮助用户掌握和运用K8S的各种命令。

一、基础命令

在Kubernetes中,基础命令用于日常的查询和基本操作。以下表格展示了这些基础命令,它们的说明,以及相应的使用举例。

命令 说明 举例
kubectl version 显示客户端和服务器的Kubernetes版本。 kubectl version
kubectl api-versions 列出可用的API版本。 kubectl api-versions
kubectl get 列出一个或多个资源。 kubectl get pods
kubectl describe 显示一个或多个资源的详细信息。 kubectl describe nodes my-node
kubectl logs 打印容器的日志。 kubectl logs my-pod
kubectl attach 附加到正在运行的容器进行交互。 kubectl attach my-pod -i
kubectl exec 在容器内执行命令。 kubectl exec my-pod -- ls /
kubectl port-forward 为Pod中的容器端口转发。 kubectl port-forward my-pod 5000:6000
kubectl proxy 运行一个代理到Kubernetes API服务器。 kubectl proxy
kubectl cp 在容器和本地文件系统之间复制文件/目录。 kubectl cp /tmp/foo_dir my-pod:/tmp/bar_dir
kubectl run 在集群中快速启动一个指定的镜像。 kubectl run nginx --image=nginx
kubectl expose 将Pod或其他资源类型暴露为Kubernetes服务。 kubectl expose deployment nginx --port=80

这些命令为Kubernetes用户提供了强大的工具集,用于管理和调试在Kubernetes集群中运行的应用。

二、资源创建与管理

在Kubernetes中,资源创建与管理命令是用于部署、更新和维护集群资源的关键工具。以下表格展示了这些命令,以及它们的说明和使用示例。

命令 说明 举例
kubectl create 从文件或stdin创建一个或多个资源。 kubectl create -f my-resource.yaml
kubectl delete 从文件、stdin或指定标签、名称、资源选择器删除资源。 kubectl delete -f my-resource.yaml
kubectl apply 应用一个或多个资源的更改。 kubectl apply -f my-resource.yaml
kubectl edit 编辑并更新服务器上一个或多个资源的定义。 kubectl edit svc/my-service
kubectl replace 从文件或stdin替换资源。 kubectl replace -f my-resource.yaml
kubectl scale 更新资源的大小。 kubectl scale --replicas=3 deployment/my-deployment
kubectl autoscale 自动扩展Pod的数量。 kubectl autoscale deployment my-deployment --min=10 --max=15
kubectl rollout 管理资源的部署。 kubectl rollout status deployment/my-deployment
kubectl set 设置特定资源的特定字段。 kubectl set image deployment/my-deployment nginx=nginx:1.9.1
kubectl auth 检查用户对于资源的权限。 kubectl auth can-i create deployments
kubectl patch 使用补丁部分更新资源的特定字段。 kubectl patch node k8s-node-1 -p '{"spec":{"unschedulable":true}}'
kubectl convert 转换配置文件到不同的API版本。 kubectl convert -f ./pod.yaml --output-version=v1
kubectl rollout history 查看Deployment或StatefulSet的历史版本。 kubectl rollout history deployment/nginx
kubectl rollout undo 回滚到Deployment或StatefulSet的旧版本。 kubectl rollout undo deployment/nginx
kubectl completion 生成shell自动补全的脚本。 kubectl completion bash
kubectl api-resources 列出API服务器上可用的资源类型。 kubectl api-resources

这些命令为开发者和系统管理员提供了广泛的工具,以灵活地处理Kubernetes资源的生命周期,包括创建、更新、删除和自动化管理。

三、集群管理与维护

Kubernetes的集群管理与维护命令涉及到集群的日常运行和维护任务,包括监控资源、管理节点和配置集群级别的设置。以下是这些命令的详细列表:

命令 说明 举例
kubectl cluster-info 显示集群信息。 kubectl cluster-info
kubectl top 显示集群中资源的当前使用情况。 kubectl top nodes
kubectl cordon 标记节点为不可调度,防止新的pods被调度到该节点。 kubectl cordon my-node
kubectl uncordon 解除节点的不可调度状态。 kubectl uncordon my-node
kubectl drain 准备节点进行维护,安全地驱逐节点上的pods。 kubectl drain my-node
kubectl quota 显示资源配额。 kubectl quota -n my-namespace
kubectl annotate 添加或更新资源的注释。 kubectl annotate pods my-pod icon-url=http://my-icon.com
kubectl label 更新资源的标签。 kubectl label pods my-pod new-label=my-label
kubectl taint 为节点添加或删除污点。 kubectl taint nodes my-node key=value:NoSchedule

这些命令为集群管理员提供了丰富的工具,用于监控和管理Kubernetes集群的健康和性能,确保集群的稳定性和效率。

四、其他指令

Kubernetes 还提供了一系列其他指令,用于执行特定的高级操作、配置管理、调试和集成扩展功能。这些指令对于深入理解和有效管理 Kubernetes 集群至关重要。

配置管理

命令 说明 举例
kubectl config 查看或修改kubeconfig文件。 kubectl config view
kubectl config get-contexts 查看所有的kubeconfig上下文。 kubectl config get-contexts
kubectl certificate 修改证书资源。 kubectl certificate approve my-cert

调试和诊断

命令 说明 举例
kubectl debug 创建调试会话。 kubectl debug node/my-node -it
kubectl diff 比较当前状态与所期望的状态。 kubectl diff -f my-resource.yaml
kubectl explain 获取资源的文档。 kubectl explain pods
kubectl wait 等待资源达到某个条件。 kubectl wait --for=condition=Ready pod/my-pod

插件和扩展

命令 说明 举例
kubectl plugin 管理kubectl插件。 kubectl plugin list
kubectl plugin list 列出已安装的插件。 kubectl plugin list

这些指令为开发人员和运维人员提供了强大的工具集,用于深入理解和管理 Kubernetes 集群的复杂性,提高日常运维的效率和效果。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
8天前
|
存储 Kubernetes Docker
Kubernetes(k8s)和Docker Compose本质区别
理解它们的区别和各自的优势,有助于选择合适的工具来满足特定的项目需求。
62 19
|
19天前
|
Kubernetes 应用服务中间件 nginx
二进制安装Kubernetes(k8s)v1.32.0
本指南提供了一个详细的步骤,用于在Linux系统上通过二进制文件安装Kubernetes(k8s)v1.32.0,支持IPv4+IPv6双栈。具体步骤包括环境准备、系统配置、组件安装和配置等。
185 10
|
23天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
2月前
|
Kubernetes Cloud Native API
深入理解Kubernetes——容器编排的王者之道
深入理解Kubernetes——容器编排的王者之道
52 1
|
2月前
|
Kubernetes Cloud Native 持续交付
深入理解Kubernetes:容器编排的基石
深入理解Kubernetes:容器编排的基石
|
2月前
|
Kubernetes 负载均衡 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第27天】Kubernetes(简称K8s)是云原生应用的核心容器编排平台,提供自动化、扩展和管理容器化应用的能力。本文介绍Kubernetes的基本概念、安装配置、核心组件(如Pod和Deployment)、服务发现与负载均衡、网络配置及安全性挑战,帮助读者理解和实践Kubernetes在容器编排中的应用。
109 4
|
2月前
|
Kubernetes 监控 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第26天】随着云计算技术的发展,容器化成为现代应用部署的核心趋势。Kubernetes(K8s)作为容器编排领域的佼佼者,以其强大的可扩展性和自动化能力,为开发者提供了高效管理和部署容器化应用的平台。本文将详细介绍Kubernetes的基本概念、核心组件、实践过程及面临的挑战,帮助读者更好地理解和应用这一技术。
78 3
|
3月前
|
Kubernetes API 调度
中间层 k8s(Kubernetes) 到底是什么,架构是怎么样的?
中间层 k8s(Kubernetes) 到底是什么,架构是怎么样的?
72 3
|
3月前
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
99 3
|
3月前
|
运维 Kubernetes Cloud Native
云原生时代的容器编排:Kubernetes入门与实践
【10月更文挑战第4天】在云计算的浪潮中,云原生技术以其敏捷、可扩展和高效的特点引领着软件开发的新趋势。作为云原生生态中的关键组件,Kubernetes(通常被称为K8s)已成为容器编排的事实标准。本文将深入浅出地介绍Kubernetes的基本概念,并通过实际案例引导读者理解如何利用Kubernetes进行高效的容器管理和服务部署。无论你是初学者还是有一定经验的开发者,本文都将为你打开云原生世界的大门,并助你一臂之力在云原生时代乘风破浪。

热门文章

最新文章