K8s 命令行

news2024/11/26 22:17:22

前言:关于k8s 与 docker

Docker和Kubernetes(通常简称为K8s)是两个在容器化应用程序方面非常流行的开源工具。

Docker:

Docker 是一种轻量级的容器化平台,允许开发者将应用程序及其所有依赖项打包到一个称为容器的可移植容器中。每个容器都运行在宿主操作系统的独立进程中,具有自己的文件系统和网络空间。Docker 提供了一种标准化的方式,使应用程序能够在不同的环境中轻松部署和运行。Docker 镜像包含了应用程序的代码、运行时、系统工具、系统库等。

Kubernetes (K8s):

Kubernetes 是一个用于自动部署、扩展和管理容器化应用程序的开源容器编排工具。它提供了一种容器编排系统,可以自动化应用程序的部署、伸缩和管理。Kubernetes 允许用户定义容器的部署、配置和调度,确保它们在整个集群中以高效和可靠的方式运行。K8s 提供了强大的功能,如自动负载均衡、滚动更新、自动扩展等,使得在大规模容器化环境中管理应用变得更加容易。

关系与区别:

  1. 关系: Docker 可以用于创建、打包和分发容器,而 Kubernetes 用于在一个集群中管理这些容器的部署、伸缩和运维。

  2. 单机 vs. 集群: Docker 主要关注单个主机上的容器化,而 Kubernetes 更专注于在多个主机上协调和管理容器。

  3. 抽象层次: Docker 提供了一个容器运行时环境,而 Kubernetes 提供了容器编排和管理的整体解决方案。

  4. 自动化: Kubernetes 提供更高级别的自动化,例如自动负载均衡、自动扩展、滚动更新等功能,使得在生产环境中更容易管理大规模应用。

通常,组合使用 Docker 和 Kubernetes 可以提供一个完整的容器化解决方案,使开发者能够方便地开发、测试和部署应用程序,并在生产环境中有效地管理这些应用程序。


kubectl 常用命令集合

1. 语法规则

kubectl [command] [TYPE] [NAME] [flags]

其中 command TYPE NAME flags 分别是:
  • command :指定要对一个或多个资源执行的操作,例如 create get describe delete 
  • TYPE :指定资源类型。资源类型不区分大小写,可以指定单数、复数或缩写形式。
例如,以下命 令输出相同的结果:
kubectl get pod pod1
kubectl get pods pod1
kubectl get po pod1
  • NAME :指定资源的名称。名称区分大小写。如果省略名称,则显示所有资源的详细信息 kubectl get pods
在对多个资源执行操作时,您可以按类型和名称指定每个资源,或指定一个或多个文件:
要按类型和名称指定资源:
要对所有类型相同的资源进行分组,请执行以下操作:
TYPE1 name1 name2 name<#> 。
例子: kubectl get pod example - pod1 example - pod2
分别指定多个资源类型:
TYPE1/name1 TYPE1/name2 TYPE2/name3 TYPE<#>/name<#> 。
例子: kubectl get pod/example - pod1 replicationcontroller/example - rc1
用一个或多个文件指定资源: - f file1 - f file2 - f file<#>
使用 YAML 而不是 JSON 因为 YAML 更容易使用,特别是用于配置文件时。
例子: kubectl get pod - f ./pod.yaml
  • flags : 指定可选的参数。例如,可以使用 -s -server 参数指定 Kubernetes API 服务器的地址和端口。
注意:
从命令行指定的参数会覆盖默认值和任何相应的环境变量。
如果您需要帮助,只需从终端窗口运行 kubectl help 即可。

1.1 get命令

kubectl get - 列出一个或多个资源。
# 查看集群状态信息
kubectl cluster-info
# 查看集群状态
kubectl get cs
# 查看集群节点信息
kubectl get nodes
# 查看集群命名空间
kubectl get ns
# 查看指定命名空间的服务
kubectl get svc -n kube-system
# 以纯文本输出格式列出所有 pod
kubectl get pods
# 以纯文本输出格式列出所有 pod ,并包含附加信息 ( 如节点名 )
kubectl get pods -o wide
# 以纯文本输出格式列出具有指定名称的副本控制器。提示:您可以使用别名 'rc' 缩短和替换
'replicationcontroller' 资源类型。
kubectl get replicationcontroller <rc-name>
# 以纯文本输出格式列出所有副本控制器和服务。
kubectl get rc,services
# 以纯文本输出格式列出所有守护程序集,包括未初始化的守护程序集。
kubectl get ds --include-uninitialized
# 列出在节点 server01 上运行的所有 pod
kubectl get pods --field-selector=spec.nodeName=server01

1.2 describe 命令

kubectl describe - 显示一个或多个资源的详细状态,默认情况下包括未初始化的资源。
# 显示名称为 <node-name> 的节点的详细信息。
kubectl describe nodes <node-name>
# 显示名为 <pod-name> pod 的详细信息。
kubectl describe pods/<pod-name>
# 显示由名为 <rc-name> 的副本控制器管理的所有 pod 的详细信息。
# 记住:副本控制器创建的任何 pod 都以复制控制器的名称为前缀。
kubectl describe pods <rc-name>
# 描述所有的 pod ,不包括未初始化的 pod
kubectl describe pods --include-uninitialized=false
说明: kubectl get 命令通常用于检索同一资源类型的一个或多个资源。 它具有丰富的参数, 允许您使用 - o -- output 参数自定义输出格式。您可以指定 - w -- watch 参数以开始观察 特定对象的更新。 kubectl describe 命令更侧重于描述指定资源的许多相关方面。它可以调用 对 API 服务器 的多个 API 调用来为用户构建视图。 例如,该 kubectl describe node 命令不 仅检索有关节点的信息,还检索在其上运行的 pod 的摘要,为节点生成的事件等。

1.3 delete命令

kubectl delete` - 从文件、 stdin 或指定标签选择器、名称、资源选择器或资源中删除资源。
# 使用 pod.yaml 文件中指定的类型和名称删除 pod
kubectl delete -f pod.yaml
# 删除标签名 = <label-name> 的所有 pod 和服务。
kubectl delete pods,services -l name=<label-name>
# 删除所有具有标签名称 = <label-name> pod 和服务,包括未初始化的那些。
kubectl delete pods,services -l name=<label-name> --include-uninitialized
# 删除所有 pod ,包括未初始化的 pod
kubectl delete pods --all

1.4 进入容器命令

kubectl exec - pod 中的容器执行命令。与 docker exec 命令非常类似
# pod <pod-name> 中获取运行 'date' 的输出。默认情况下,输出来自第一个容器。
kubectl exec <pod-name> date
# 运行输出 'date' 获取在容器的 <container-name> pod <pod-name> 的输出。
kubectl exec <pod-name> -c <container-name> date
# 获取一个交互 TTY 并运行 /bin/bash <pod-name > 。默认情况下,输出来自第一个容器。
kubectl exec -ti <pod-name> /bin/bash

1.5 logs命令

kubectl logs - 打印 Pod 中容器的日志。
# pod 返回日志快照。
kubectl logs <pod-name>
# pod <pod-name> 开始流式传输日志。这类似于 'tail -f' Linux 命令。
kubectl logs -f <pod-name>

1.6 格式化输出

pod 信息格式化输出到一个 yaml 文件
kubectl get pod web-pod-13je7 -o yaml

1.7 资源缩写汇总

2. namespace 命名空间

kubectl get namespace
查看所有命名空间的 pod 资源
kubectl get pod --all-namespaces
kubectl get pod -A
简写命令
kubectl get ns
default 用户创建的 pod 默认在此命名空间
kube-public 所有用户均可以访问,包括未认证用户
kube-node-lease kubernetes 集群节点租约状态 ,v1.13 加入
kube-system kubernetes 集群在使用

3.pod

Pod kubernetes 集群能够调度的最小单元。 Pod 是容器的封装
查看 default 命名空间下的 pods
kubectl get pods
查看 kube-system 命名空间下的 pods
kubectl get pods -n kube-system
查看所有命名空间下的 pods
kubectl get pod --all-namespaces
kubectl get pod -A

3.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1219173.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

学习笔记5——对象、直接内存、执行引擎,string

学习笔记系列开头惯例发布一些寻亲消息 链接&#xff1a;https://baobeihuijia.com/bbhj/contents/3/192486.html 创建对象的步骤 对象对应的类是否被加载&#xff0c;链接&#xff08;链接到真实的内存地址&#xff09;&#xff0c;初始化&#xff08;类初始化&#xff09;…

2023 年 数维杯(B题)国际大学生数学建模挑战赛 |数学建模完整代码+建模过程全解全析

当大家面临着复杂的数学建模问题时&#xff0c;你是否曾经感到茫然无措&#xff1f;作为2021年美国大学生数学建模比赛的O奖得主&#xff0c;我为大家提供了一套优秀的解题思路&#xff0c;让你轻松应对各种难题。 让我们来看看数维杯&#xff08;B题&#xff09;&#xff01; …

【softmax和sidmod 快速学习和 用法对比】

Softmax函数和Sigmoid函数&#xff08;也称为Logistic函数&#xff09;在某些方面有相似之处&#xff0c;但它们在使用和适用场景上有一些不同。 首先&#xff0c;Sigmoid函数适用于二分类问题&#xff0c;将模型输出映射到0和1之间的概率值&#xff0c;表示样本属于正类的概率…

Git面经

Git八股文 第一章 git基础 1.1 什么是git git是一款免费的开源的分布式版本控制系统 1.2 为什么要使用git 为了保留之前的所有版本&#xff0c;方便回滚或修改 1.3 集中化版本控制系统和分布式版本控制系统的区别 集中化版本控制系统如svn&#xff0c;客户端连接到中央服…

RedHat公司及红帽认证介绍丨红帽认证等级介绍

RedHat公司及红帽认证介绍 红帽公司成立工1993年&#xff0c;是全球首家收入超10亿美元的开源公司&#xff0c;总部位于美国&#xff0c;分支机构遍布全球。红帽公司作头全球领先的开源和Linux系统提供商&#xff0c;其产品已被业界广泛认可并使用&#xff0c;尤其是RHEL系统在…

AD教程 (十七)3D模型的创建和导入

AD教程 &#xff08;十七&#xff09;3D模型的创建和导入 对于设计者来讲&#xff0c;现在3DPCB比较流行&#xff0c;3DPCB&#xff0c;除了美观之外&#xff0c;做3D的最终的一个目的&#xff0c;是为了去核对结构&#xff0c;就是我们去做了这么一个PCB之后&#xff0c;如果说…

033、微调

之——高级炼丹术 目录 之——高级炼丹术 杂谈 正文 1.标注数据集是很贵的 2.微调的思想 3.尝试 小结 杂谈 微调&#xff08;Fine-tuning&#xff09;是深度学习中的一种常见策略&#xff0c;它通常用于预训练模型在特定任务上的性能提升。微调的过程涉及在一个已经在大…

构建自定义ChatGPT,微软推出Copilot Studio

11月16日&#xff0c;微软在美国西雅图举办“Microsoft Ignite 2023”全球开发者大会。本次人工智能成为重要主题&#xff0c;微软几乎把所有产品都集成了生成式AI功能并发布了一系列全新产品。 其中&#xff0c;微软重磅推出了Copilot Studio&#xff08;预览版&#xff09;&…

001.前置知识

1、硬件 我们知道&#xff0c;组成计算机的硬件主要有“主机”和“输入/输出设备”。 主机包括机箱、电源、主板、CPU&#xff08;Central Processing Unit&#xff0c;中央处理器&#xff09;、内存、显卡、声卡、网卡、 硬盘、光驱等。输入/输出设备包括显示器、键盘、鼠标…

五分钟,Docker安装kafka 3.5,kafka-map图形化管理工具

首先确保已经安装docker&#xff0c;如果是windows安装docker&#xff0c;可参考 wsl2安装docker 1、安装zk docker run -d --restartalways -e ALLOW_ANONYMOUS_LOGINyes --log-driver json-file --log-opt max-size100m --log-opt max-file2 --name zookeeper -p 2181:218…

ssm+vue的OA办公系统(有报告)。Javaee项目,ssm vue前后端分离项目。

演示视频&#xff1a; ssmvue的OA办公系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;ssm vue前后端分离项目。 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 项目介绍&a…

中心极限定理

中心极限定理是统计学中的一个基本定理&#xff0c;它描述了在满足一定条件的情况下&#xff0c;独立随机变量的均值的分布会在样本容量足够大时趋近于正态分布。中心极限定理为许多统计推断方法的合理性提供了理论基础。 中心极限定理有两种常见的表述&#xff1a;独立同分布…

数据库逗号分割数据查询

遇到一个A表某个字段是B表某个字段拼接而成的。 A一对多B表 即表A某个字段存了B表多个单号或者多个ID&#xff0c;一开始想的是要处理数据想办法分割字符串出来然后关联&#xff0c;百度了下没找到&#xff0c;但是看到PostgreSql数据库可以实现 然后尝试了下 发现可以 第一…

学习指南:如何快速上手媒体生态一致体验开发

过去开发者们在使用多媒体能力时&#xff0c;往往会遇到这样的问题&#xff0c;比如&#xff1a;为什么我开发的相机不如系统相机的效果好&#xff1f;为什么我的应用和其他的音乐一起发声了&#xff0c;我要怎么处理&#xff1f;以及我应该怎么做才能在系统的播控中心里可以看…

中文撰稿好用软件推荐TexPage(似于Overleaf)

由于本人用惯了overleaf所以找到了一个与他功相似的也同样是利用tex写文章。唯一的区别可能也就是overleaf只支持英文&#xff0c;而TexPage中英文都支持。关键是不花钱&#xff0c;好用好用好用&#xff0c;用起来&#xff01; 平台网址&#xff1a;https://www.texpage.com/…

C/C++算法-----------------------双指针详解技巧及例题

双指针 基本介绍降低时间复杂度降低时间复杂度例题 验证回文串判断是否为环反转链表总结 基本介绍 双指针&#xff08;two poinnters&#xff09;实际上是一种算法编程里的一种思想&#xff0c;它更像是一种编程思想&#xff0c;提供看非常高的算法效率&#xff0c;一般来说双…

Android——gradle插件配置方式——dependencies和plugins

引言 我们知道Android studio 需要gradle插件进行构建和编译&#xff0c;随着AGP的升级&#xff0c;引入gradle插件也发生了变化。旧版本通过build.gradle文件中dependencies代码块引入&#xff0c;新版本通过plugins代码块引入 一、旧版本引入方式dependencies 二、新版本引入…

解决java在idea运行正常,但是打成jar包后中文乱码问题

目录 比如&#xff1a; 打包命令使用utf-8编码&#xff1a; 1.当在idea中编写的程序,运行一切正常.但是当被打成jar包时,执行的程序会中文乱码.产生问题的原因和解决方案是什么呢? 一.问题分析 分别使用idea和jar包形式打印出System中所有的jvm参数---代码如下: public static…

一文揭秘共享wifi二维码项目推广技巧!

随着无线网络的普及和移动互联网的快速发展&#xff0c;共享WiFi已成为人们生活中不可或缺的一部分。共享WiFi二维码项目作为一个独具创意的共享项目&#xff0c;将二维码推广与共享WiFi相结合&#xff0c;不仅可以提升品牌曝光度&#xff0c;还能为用户提供便捷的上网体验。那…