Kubernetes(K8S)命令指南
本文提供了一份全面的Kubernetes(K8S)命令指南,旨在帮助用户掌握和运用K8S的各种命令。
关注【TechLeadCloud】,分享互联网架构、云服务技术的全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人

一、基础命令
在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 集群的复杂性,提高日常运维的效率和效果。
关注【TechLeadCloud】,分享互联网架构、云服务技术的全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人
如有帮助,请多关注
TeahLead KrisChang,10+年的互联网和人工智能从业经验,10年+技术和业务团队管理经验,同济软件工程本科,复旦工程管理硕士,阿里云认证云服务资深架构师,上亿营收AI产品业务负责人。
Kubernetes(K8S)命令指南的更多相关文章
- kubernetes(k8s)命令大全
状态查询 # 查看集群信息 # kubectl cluster-info Kubernetes control plane is running at https://127.0.0.1:8443 K ...
- 使用kubectl管理Kubernetes(k8s)集群:常用命令,查看负载,命名空间namespace管理
目录 一.系统环境 二.前言 三.kubectl 3.1 kubectl语法 3.2 kubectl格式化输出 四.kubectl常用命令 五.查看kubernetes集群node节点和pod负载 5 ...
- Kubernetes 实践指南之Kubernetes 的命令行工具详解
kubectl作为客户端CLI工具,可以让用户通过命令行的方式对Kubernetes集群进行管理.本节内容将对kubectl的子命令和用法进行详细描述. 一.kubectl 用法概述 kubectl语 ...
- Kubernetes K8S之资源控制器RC、RS、Deployment详解
Kubernetes的资源控制器ReplicationController(RC).ReplicaSet(RS).Deployment(Deploy)详解与示例 主机配置规划 服务器名称(hostna ...
- 《k8s权威指南》读书笔记
抽空读完了<k8s权威指南>一书,对k8s的总算有了较为系统的认知. 好记忆不如多写字,以下是读书笔记 第一章 k8s入门 k8s是什么: 一个开源的容器集群管理平台,可提供容器集群的自动 ...
- 《两地书》--Kubernetes(K8s)基础知识(docker容器技术)
大家都知道历史上有段佳话叫“司马相如和卓文君”.“皑如山上雪,皎若云间月”.卓文君这么美,却也抵不过多情女儿薄情郎. 司马相如因一首<子虚赋>得汉武帝赏识,飞黄腾达之后便要与卓文君“故来相 ...
- Docker Kubernetes(K8s)简介
入职了新公司,使用了Docker和K8s,需要有一个基础的了解,对网络上相关信息进行了简单总结. 一Docker 1简介: Docker 将应用程序与该程序的依赖,打包在一个文件里面.运行这个文件,就 ...
- Kubernetes(k8s) docker集群搭建
原文地址:https://blog.csdn.net/real_myth/article/details/78719244 一.Kubernetes系列之介绍篇 •Kubernetes介绍 1.背 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之自签TLS证书及Etcd集群部署(二)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.服务器设置 1.把每一 ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之flanneld网络介绍及部署(三)
0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.flanneld介绍 ...
随机推荐
- Oracle不走索引的原因
Oracle数据库操作中,为什么有时一个表的某个字段明明有索引,当观察一些语的执行计划确不走索引呢?如何解决呢?本文我们主要就介绍这部分内容,接下来就让我们一起来了解一下 . 不走索引大体有以下几个原 ...
- Java 设计模式----单例模式的几种实现方式
单例模式的几种实现方式 单例模式的实现有多种方式,如下所示: 1.懒汉式,线程不安全 是否 Lazy 初始化:是 是否多线程安全:否 实现难度:易 描述:这种方式是最基本的实现方式,这种实现最大的问题 ...
- 在Visual Studio 中使用git系列文章目录
在Visual Studio 中使用git--什么是Git(一) 在Visual Studio 中使用git--给Visual Studio安装 git插件(二) 在Visual Studio 中使用 ...
- SSH原理与实践(三)安装和使用
主页 个人微信公众号:密码应用技术实战 个人博客园首页:https://www.cnblogs.com/informatics/ 引言 在之前SSH原理与实践系列文章中,我们主要讲解了SSH协议的原理 ...
- Pod中断预算 PodDisruptionBudget(PDB)
PodDisruptionBudget(PDB)是Kubernetes中的一个资源对象,用于确保在进行维护.升级或其他操作时,系统中的Pod不会被意外中断或终止.PDB提供了一种机制,通过限制在给定时 ...
- 【实时渲染】3DCAT实时渲染云在BIM领域的应用
很多人不知道实时渲染云在BIM领域都有哪些应用,今天3DCAT就为大家整理了一篇关于实时渲染云在BIM领域的应用介绍的文章.我们将会从什么是BIM.BIM在协作方面的挑战.3DCAT的解决方案及3DC ...
- 观展新体验!3DCAT助力青桔 “未来之见”线上发布会炫酷亮相
在"未来之见"滴滴青桔2021新品发布会现场,青桔推出概念车"青桔X","X"代表了无限可能和憧憬,街边的共享单车?这只是其中一面,青桔为您 ...
- JS(循环)
一 for循环 在程序中,一组被重复执行的语句被称之为循环体,能否继续重复执行,取决于循环的终止条件.由循环体及循环的终止条件组成的语句,被 称之为循环语句 1 语法结构 for循环主要用于把某些代码 ...
- 【Leetcode】64. 最小路径和
题目(链接) 给定一个包含非负整数的m x n网格grid,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. 说明:每次只能向下或者向右移动一步. 示例 1: 输入:grid = [[1 ...
- Python 合并Excel文件(Excel文件多sheet)
一.Python合并Excel文件多sheet<方法1> import os import pandas as pd # 指定包含Excel文件的文件夹路径 folder_path = ' ...