K8s(Kubernetes)常用命令
大家好,当谈及容器编排工具时,Kubernetes(常简称为K8s)无疑是当今最受欢迎和广泛使用的解决方案之一。作为一个开源的容器编排平台,Kubernetes 提供了丰富的功能,可以帮助开发人员和运维团队管理、部署和扩展容器化应用程序。然而,要充分发挥 Kubernetes 的潜力,理解和掌握其各种命令是至关重要的。
本文将介绍一些常用的 Kubernetes 命令,从基本的集群管理到应用程序部署和监控,旨在帮助读者更好地理解和利用 Kubernetes。无论您是初学者还是有经验的 Kubernetes 用户,本文都将为您提供有价值的信息和技巧,助您更轻松地管理和操作 Kubernetes 集群。
一、Kubernetes 概述
Kubernetes(通常简称为 K8s)是一个开源的容器编排平台,最初由 Google 开发,并于2014年开源。它旨在简化容器化应用程序的部署、扩展和管理。
作用与优势
Kubernetes 的主要作用是自动化容器操作,例如部署、调度和管理容器化的应用程序。它提供了一种高度可扩展的平台,可以在跨多个主机上动态管理容器化应用程序的资源。
Kubernetes 的优势包括:
-
自动化部署和扩展: Kubernetes 可以自动部署和扩展应用程序,根据负载需求动态调整容器的数量。
-
服务发现与负载均衡: Kubernetes 提供了内置的服务发现和负载均衡功能,使得应用程序可以轻松地与其他服务通信。
-
自我修复: Kubernetes 可以自动检测容器和节点的健康状态,并在需要时进行自我修复,确保应用程序的高可用性。
-
密钥管理与配置: Kubernetes 提供了安全的密钥管理和配置管理功能,可以轻松地管理敏感信息和应用程序配置。
-
多环境支持: Kubernetes 可以在公有云、私有云和混合云环境中运行,为用户提供了更大的灵活性和选择性。
-
社区支持与生态系统: Kubernetes 拥有庞大的开源社区和丰富的生态系统,提供了大量的工具和插件,使得用户能够定制化和扩展 Kubernetes 平台。
在容器编排中的重要性
在容器编排中,Kubernetes 起着至关重要的作用。它允许开发人员和运维团队管理和调度大规模容器化应用程序,确保它们能够高效、可靠地运行。Kubernetes 提供了一个统一的平台,使得容器化应用程序的部署、扩展和管理变得更加简单和可靠。通过 Kubernetes,团队可以更快地交付软件,提高应用程序的可用性和可伸缩性,从而降低了部署和运维的成本,促进了业务的持续创新和发展。
二、常用命令
当涉及到 Kubernetes(通常缩写为 K8s)集群的管理和操作时,有一些常用的命令是非常重要的。以下是一些常见的 Kubernetes 命令及其功能:
1、kubectl get
获取资源的信息。这是一个非常常用的命令,可以用来获取各种 Kubernetes 资源的状态信息,比如 Pods、Services、Deployments 等。
kubectl get pods # 获取所有 Pods 的信息
kubectl get services # 获取所有 Services 的信息
kubectl get deployments # 获取所有 Deployments 的信息
2、kubectl describe
获取资源的详细信息。该命令可以显示特定资源的详细信息,包括各种配置和状态。
kubectl describe pod <pod_name> # 获取特定 Pod 的详细信息
kubectl describe service <service_name> # 获取特定 Service 的详细信息
3、kubectl create
创建资源。使用此命令可以在 Kubernetes 中创建各种资源,例如 Pod、Service、Deployment 等。
kubectl create deployment <deployment_name> --image=<image_name> # 创建 Deployment
kubectl create service <service_name> --tcp=<port>:<targetPort> # 创建 Service
4、kubectl delete
删除资源。这个命令用于删除指定的资源,可以是单个资源或一组资源。
kubectl delete pod <pod_name> # 删除 Pod
kubectl delete service <service_name> # 删除 Service
5、kubectl apply
应用配置。通过 apply 命令可以将配置文件应用到 Kubernetes 集群中,包括创建、更新和删除资源。
kubectl apply -f <filename.yaml> # 应用配置文件
6、kubectl exec
在容器内执行命令。可以使用 exec 命令在运行的容器内执行命令,例如查看日志或执行调试操作。
kubectl exec -it <pod_name> -- /bin/bash # 进入 Pod 的 shell 环境
kubectl exec <pod_name> -- ls # 在 Pod 内执行 ls 命令
7、kubectl logs
获取容器日志。该命令用于检索 Pod 中容器的日志信息。
kubectl logs <pod_name> # 获取 Pod 中所有容器的日志
kubectl logs <pod_name> -c <container_name> # 获取 Pod 中特定容器的日志
8、kubectl scale
扩展 Deployment。使用 scale 命令可以扩展或缩减 Deployment 中 Pod 的副本数量。
kubectl scale deployment <deployment_name> --replicas=<num_replicas> # 扩展 Deployment 的副本数量
9、kubectl port-forward
将本地端口与 Pod 的端口进行转发,以便直接访问 Pod 内的服务。
kubectl port-forward <pod_name> <local_port>:<pod_port> # 将本地端口与 Pod 端口进行转发
10、kubectl rollout
管理 Deployment 的滚动更新。可以使用 rollout 命令进行滚动更新的管理,包括查看历史记录、回滚等。
kubectl rollout status deployment/<deployment_name> # 查看 Deployment 的更新状态
kubectl rollout history deployment/<deployment_name> # 查看 Deployment 的更新历史
kubectl rollout undo deployment/<deployment_name> # 回滚 Deployment 到上一个版本
11、kubectl label
标记资源。使用 label 命令可以给资源添加标签,以便进行更灵活的资源选择和管理。
kubectl label pods <pod_name> <label_key>=<label_value> # 给 Pod 添加标签
kubectl label nodes <node_name> <label_key>- # 删除 Node 的标签
12、kubectl taint
标记节点的污点。污点可以阻止 Pod 调度到节点上,除非 Pod 明确容忍该污点。
kubectl taint nodes <node_name> <taint_key>=<taint_value>:<effect> # 给节点添加污点
13、kubectl get events
获取集群事件。该命令用于获取集群中发生的事件,如 Pod 的创建、删除、调度等。
kubectl get events # 获取集群中的事件列表
kubectl describe events # 查看详细的事件信息
14、kubectl top
查看集群资源的使用情况。可以使用 top 命令查看集群中各种资源(如 CPU、内存)的使用情况。
kubectl top node # 查看节点的资源使用情况
kubectl top pod # 查看 Pod 的资源使用情况
15、kubectl proxy
启动本地代理。可以使用 proxy 命令在本地启动代理,以便访问 Kubernetes API 服务器。
kubectl proxy # 启动本地代理
16、kubectl edit
编辑资源配置。使用 edit 命令可以直接编辑 Kubernetes 资源的配置,比如 Deployment、Service 等。
kubectl edit deployment <deployment_name> # 编辑 Deployment 的配置
17、kubectl create secret
创建密钥或凭据。可以使用 create secret 命令创建 Kubernetes 中的密钥或凭据,用于存储敏感信息。
kubectl create secret generic <secret_name> --from-literal=<key>=<value> # 创建通用密钥
18、kubectl rollout pause/resume
暂停和恢复 Deployment 的滚动更新。可以使用 pause 和 resume 命令暂停和恢复 Deployment 的滚动更新过程。
kubectl rollout pause deployment/<deployment_name> # 暂停 Deployment 的滚动更新
kubectl rollout resume deployment/<deployment_name> # 恢复 Deployment 的滚动更新
19、kubectl get pod|service|deployment --watch
实时监视资源。使用 watch 参数可以实时监视特定资源的状态变化。
kubectl get pods --watch # 实时监视 Pods 的状态变化
20、kubectl explain
查看资源的详细信息和字段说明。使用 explain 命令可以查看 Kubernetes 资源的详细说明,包括支持的字段等。
kubectl explain pod.spec.containers # 查看 Pod 中容器的字段说明
相关文章:

K8s(Kubernetes)常用命令
大家好,当谈及容器编排工具时,Kubernetes(常简称为K8s)无疑是当今最受欢迎和广泛使用的解决方案之一。作为一个开源的容器编排平台,Kubernetes 提供了丰富的功能,可以帮助开发人员和运维团队管理、部署和扩…...
C#-for循环语句
for循环语句 语法: for(初始化变量; 判断条件; 增量表达式) { // 内部代码 } 第一个空(初始表达式): 一般用来声明一个临时的局部变量 用来计数第二个空(条件表达式): 表明进入循环的条件 一个bool类型的值(bool类型 条件表达式 逻辑运算符)第三个空(增量表达式): 使用第一个空…...

css动画案例练习之会展开的魔方和交错的小块
这里写目录标题 一级目录二级目录三级目录 下面开始案例的练习,建议第一个动手操作好了再进行下一个一、交错的小块效果展示1.大致思路1.基本结构2.实现动态移动 2.最终版代码 二、会展开的魔方1.大致思路1.基本结构;2.静态魔方的构建3.让静态的魔方动起来 2.最终版…...

前端逆向之下载canvas引用的图片
前端逆向之下载canvas引用的图片 一、来源二、解决三、如果在Network这里也找不到呢? 一、来源 当我们用dom检查器的时候无法选中想要扒下来的图片,只能选中canvas,这种时候该怎么办呢? 二、解决 这个时候应该换个脑子…...
深度学习手撕代码题
目录: PyTorch实现注意力机制、多头注意力与自注意力Numpy广播机制实现矩阵间L2距离的计算Conv2D卷积的Python和C++实现Numpy实现bbox_iou的计算Numpy实现FocallossPython实现nms、softnmsPython实现BN批量归一化PyTorch卷积与BatchNorm的融合分割网络损失函数Dice Loss代码实…...

vue3 + ts 动态添加路由,刷新页面白屏问题解决方案
1、store 中添加路由的方法 2、main.ts中使用该方法 然后就可以任意刷新页面了,有问题可以随时滴我...........

【Kubernetes】k8s的调度约束(亲和与反亲和)
一、调度约束 list-watch 组件 Kubernetes 是通过 List-Watch 的机制进行每个组件的协作,保持数据同步的,每个组件之间的设计实现了解耦。 用户是通过 kubectl 根据配置文件,向 APIServer 发送命令,在 Node 节点上面建立 Pod 和…...

Java数据结构- Map和Set
目录 1. Map和Set2. Map的使用3. Set的使用 1. Map和Set Java中,Map和Set是两个接口,TreeSet、HashSet这两个类实现了Set接口,TreeMap、HashMap这两个类实现了Map接口。 带Tree的这两个类(TreeSet、TreeMap)底层的数…...

JVM参数配置
JVM参数的三种表示方法 在jvm中,jvm虚拟机参数有以下三种表示方法: 标准参数(-)所有的JVM实现都必须实现这些参数的功能,而且向后兼容非标准参数(-X),默认jvm实现这些参数的功能&…...
Vue 实现的精彩动画效果
在 Vue 开发中,我们可以利用<transition>组件来打造各种令人惊艳的动画效果。下面来详细看看这些有趣的动画效果及其实现代码。 一、缩放类效果 zoom-in(整体放大进入) <template><div><button click"isShow ! …...

JVM类加载机制详解(JDK源码级别)
提示:从JDK源码级别彻底剖析JVM类加载机制、双亲委派机制、全盘负责委托机制、打破双亲委派机制的程序、Tomcat打破双亲委派机制、tomcat自定义类加载器详解、tomcat的几个主要类加载器、手写tomcat类加载器 文章目录 前言一、loadClass的类加载大概有如下步骤二、j…...

美国年轻人热衷床上“摆烂”,沃尔玛发掘床上用品新商机!
美国年轻人近年来热衷于床上“摆烂”生活方式,这反映了他们对舒适放松的追求和现代生活的压力。沃尔玛作为零售业巨头,敏锐地捕捉到这一市场变化,发现了床上用品的新商机。 美国年轻人忙碌中渴望宁静空间。床成为他们放松、逃离现实压力的理想…...
3168. 候诊室中的最少椅子数
给你一个字符串 s,模拟每秒钟的事件 i: 如果 s[i] E,表示有一位顾客进入候诊室并占用一把椅子。如果 s[i] L,表示有一位顾客离开候诊室,从而释放一把椅子。 返回保证每位进入候诊室的顾客都能有椅子坐的 最少 椅子…...

C# PaddleOCR 单字识别效果
C# PaddleOCR 单字识别效果 效果 说明 根据《百度办公文档识别C离线SDKV1.2用户接入文档.pdf》,使用C封装DLL,C#调用。 背景 为使客户、第三方开发者等能够更快速、方便的接入使用百度办公文档识别 SDK、促进百度 OCR产品赋能更多客户,特设…...

pyopengl 立方体 正投影,透视投影
目录 顶点和线的方式 划线的方式实现: 顶点和线的方式 import numpy as np from PyQt5 import QtWidgets from PyQt5.QtCore import Qt from PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton from OpenGL.GL import * from OpenGL.GLU import * import sys…...

人工智能任务5-高级算法工程师需要学习哪些课程与掌握哪些能力
大家好,我是微学AI,今天给大家介绍一下人工智能的任务5-高级算法工程师需要学习哪些课程,需要掌握哪些能力。高级算法工程师需要掌握的算法模型有:人脸检测模型MTCNN,人脸识别方法Siamese network、center loss、softm…...

服务器上创建搭建gitlab
一、下载与安装 在主目录操作~ 1.使用wget下载 wget --no-check-certificate https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-14.0.1-ce.0.el7.x86_64.rpm 可以在开源软件镜像站选择合适的版本,版本不同页面菜单会稍有差异,此次选…...
LangChain学习之prompt格式化与解析器使用
1. 学习背景 在LangChain for LLM应用程序开发中课程中,学习了LangChain框架扩展应用程序开发中语言模型的用例和功能的基本技能,遂做整理为后面的应用做准备。视频地址:基于LangChain的大语言模型应用开发构建和评估高 2. 先准备尝试调用O…...

基于EasyX的贪吃蛇小游戏 - C语言
游戏基本功能演示: 1.主菜单界面 2.自定难度界面 在这里可以自行设定游戏的难度,包括蛇的移动速度,初始节数,以及默认模式,参考线(网格)。这些设定的数据都会在右上角的游戏属性栏中实时显示。…...
使用Docker辅助图像识别程序开发:在Docker中显示GUI、访问GPU、USB相机以及网络
目录概览 引言安装和配置安装docker安装nvidia-docker在docker中显示GUI在Docker中访问usb相机在Docker镜像中开放端口开启更多的GPU功能支持创建本地镜像中心一些可选参数上传镜像回收空间清理所有的无用镜像清理指定的镜像GPU Docker with Anaconda第一种方式:构建DockerFile…...
内存分配函数malloc kmalloc vmalloc
内存分配函数malloc kmalloc vmalloc malloc实现步骤: 1)请求大小调整:首先,malloc 需要调整用户请求的大小,以适应内部数据结构(例如,可能需要存储额外的元数据)。通常,这包括对齐调整,确保分配的内存地址满足特定硬件要求(如对齐到8字节或16字节边界)。 2)空闲…...
前端倒计时误差!
提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南 在数字化营销时代,邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天,我们将深入解析邮件打开率、网站可用性、页面参与时…...

HDFS分布式存储 zookeeper
hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架,允许使用简单的变成模型跨计算机对大型集群进行分布式处理(1.海量的数据存储 2.海量数据的计算)Hadoop核心组件 hdfs(分布式文件存储系统)&a…...

初探Service服务发现机制
1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能:服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源…...

iview框架主题色的应用
1.下载 less要使用3.0.0以下的版本 npm install less2.7.3 npm install less-loader4.0.52./src/config/theme.js文件 module.exports {yellow: {theme-color: #FDCE04},blue: {theme-color: #547CE7} }在sass中使用theme配置的颜色主题,无需引入,直接可…...

【网络安全】开源系统getshell漏洞挖掘
审计过程: 在入口文件admin/index.php中: 用户可以通过m,c,a等参数控制加载的文件和方法,在app/system/entrance.php中存在重点代码: 当M_TYPE system并且M_MODULE include时,会设置常量PATH_OWN_FILE为PATH_APP.M_T…...
libfmt: 现代C++的格式化工具库介绍与酷炫功能
libfmt: 现代C的格式化工具库介绍与酷炫功能 libfmt 是一个开源的C格式化库,提供了高效、安全的文本格式化功能,是C20中引入的std::format的基础实现。它比传统的printf和iostream更安全、更灵活、性能更好。 基本介绍 主要特点 类型安全:…...
0x-3-Oracle 23 ai-sqlcl 25.1 集成安装-配置和优化
是不是受够了安装了oracle database之后sqlplus的简陋,无法删除无法上下翻页的苦恼。 可以安装readline和rlwrap插件的话,配置.bahs_profile后也能解决上下翻页这些,但是很多生产环境无法安装rpm包。 oracle提供了sqlcl免费许可,…...