k8s——kubectl

2023-11-07

目录

一、k8s管理操作方法

二、陈述式资源管理方法

1、基本信息查看

1.1 查看k8s版本信息

1.2 查看资源对象简写

1.3 查看集群信息

1.4 配置kubectl自动补全

1.5 node节点查看日志

2、基本信息查看

2.1 查看master 节点状态

2.2 查看命令空间

2.3 查看default命名空间的所有资源

2.4 创建命名空间app

2.5 删除命名空间app

2.6 在命名空间kube-public 创建副本控制器( deployment) 来启动Pod (nginx-test)

2.7 描述某个资源的详细信息

2.8 查看命名空间kube-public中的pod信息

2.9 kubectl exec可以跨主机登录容器,docker exec 只能在容器所在主机上登录

2.10 删除(重启) pod资源, 由于存在deployment/rc之类的副本控制器,删除pod也会重新拉起来

2.11 若pod无法删除,总是处于terminate状态, 则要强行删除pod

2.12 扩缩容

2.13 删除副本控制器(两种表示方法) 

3、项目的生命周期

3.1 创建kubectl run命令

3.2 发布kubectl expose命令

3.3 更新kubect1 set

3.4 回滚kubectl rollout

3.5 删除kubectl delete

4、金丝雀发布(Canary Release)——陈述式管理方法

1、更新deployment的版本,并配置暂停deployment

2、监控更新的过程,可以看到已经新增了一个资源,但是并未按照预期的状态去删除一个旧的资源, 就是因为使用了pause暂停命令

3、确保更新的pod没问题了,继续更新

4、查看最后的更新情况

三、声明式管理方法

kubectl create 和 kubectl apply区别

1、查看资源配置清单

2、解释资源配置清单

 2、声明式资源管理办法


一、k8s管理操作方法

k8s管理操作分为两大类

1、陈述式资源管理方法:通过命令方式语句来实现对资源管理,一条命令来实现

2、声明式资源管理方法:那我们之前来通过yaml文件资源现配置所在的一个yaml和josn配置文件当中

二、陈述式资源管理方法

  1. kubernetes集群管理集群资源的唯一入口是通过相应的方法调用apiserver的接口
  2. kubectl 是官方的CLI命令行工具,用于与apiserver 进行通信,将用户在命令行输入的命令,组织并转化为apiserver能识别的信息,进而实现管理k8s 各种资源的一种有效途径
  3. kubectl 的命令大全
    1. kubectl --help
    2. k8s中文文档: Kubernetes kubectl 命令表
  4. 对资源的增、删、查操作比较方便,但对改的操作就不容易了

1、基本信息查看

1.1 查看k8s版本信息

//查看k8s版本信息
kubectl version

1.2 查看资源对象简写

//查看资源对象简写
kubectl api-resources

1.3 查看集群信息

//查看集群信息 
kubectl cluster-info

1.4 配置kubectl自动补全

//配置kubectl自动补全
source <(kubectl completion bash)

1.5 node节点查看日志

//node节点查看日志
journalctl -u kubelet -f

2、基本信息查看

kubectl get <resource> [-o wide | json | yaml] [-n namespace]  

获取资源的相关信息,-n指定命令空间,-o指定输出格式

resource可以是具体资源名称,如pod nginx -xxx;也可以是资源类型,如pod; 或者all (仅展示几种核心资源,并不完整)

--all-namespaces 或-A :表示显示所有命令空间,

--show-labels :显示所有标签

-l app:仅显示标签为app的资源

-l app=nginx :仅显示包含app标签, 且值为nginx的资源

2.1 查看master 节点状态

//查看 master 节点状态
kubectl get componentstatuses
kubectl get cs

2.2 查看命令空间

//查看命令空间
kubectl get namespace
kubectl get ns
//命令空间的作用:用于允许不同 命令空间 的 相同类型 的资源 重名的

2.3 查看default命名空间的所有资源

//查看default命名空间的所有资源
kubectl get all [-n default]

2.4 创建命名空间app

//创建命名空间xx
kubectl create ns xx
kubectl get ns

2.5 删除命名空间app

//删除命名空间xx
kubectl delete namespace xx
kubectl get ns

2.6 在命名空间kube-public 创建副本控制器( deployment) 来启动Pod (nginx-test)

//在命名空间kube-public 创建副本控制器(deployment)来启动Pod(nginx-test)
kubectl create deployment nginx-test --image=nginx  -n kube-public

2.7 描述某个资源的详细信息

//描述某个资源的详细信息
kubectl describe deployment nginx-test -n kube-public
kubectl describe pod nginx-test-795d659f45 -n kube-public

2.8 查看命名空间kube-public中的pod信息

//查看命名空间kube-public 中的pod 信息
kubectl get pods -n kube-public
NAME                       READY   STATUS    RESTARTS   AGE
nginx-test-d47f99cb6-hv6gz   1/1     Running   0          24m

2.9 kubectl exec可以跨主机登录容器,docker exec 只能在容器所在主机上登录

//kubectl exec可以跨主机登录容器,docker exec 只能在容器所在主机上登录
kubectl exec -it nginx-test-d47f99cb6-hv6gz bash -n kube-public

2.10 删除(重启) pod资源, 由于存在deployment/rc之类的副本控制器,删除pod也会重新拉起来

//删除(重启)pod资源,由于存在deployment/rc之类的副本控制器,删除pod也会重新拉起来
kubectl delete pod nginx-test-d47f99cb6-hv6gz -n kube-public

2.11 若pod无法删除,总是处于terminate状态, 则要强行删除pod

//若pod无法删除,总是处于terminate状态,则要强行删除pod
kubectl delete pod <pod-name> -n <namespace> --force --grace-period=0
#grace-period表示过渡存活期,默认30s,在删除pod之前允许POD慢慢终止其上的容器进程,从而优雅退出,0表示立即终止pod

2.12 扩缩容

//扩缩容
kubectl scale deployment nginx-test --replicas=2 -n kube-public	# 扩容
kubectl scale deployment nginx-test --replicas=1 -n kube-public	# 缩容

2.13 删除副本控制器(两种表示方法) 

//删除副本控制器
kubectl delete deployment nginx-test -n kube-public
kubectl delete deployment/nginx-test -n kube-public

3、项目的生命周期

生命周期:创建 —>> 发布 —>> 更新 —>> 回滚 —>> 删除

3.1 创建kubectl run命令

●创建并运行一个或多个容器镜像

●创建一个deployment或job来管理容器

-------------------------------

kubectl run  用于创建一个自主式/静态Pod

kubectl delete pod

kubectl create deployment   用于创建deployment控制器管理的pod

kubectl delete deployment

kubectl sacle --replicas

查看信息:

kubectl   get    pods/svc/ns/cs/node/all

--------------------------------------

kubectl run --help

//启动nginx 实例,暴露容器端口80,设置副本数3

kubectl run nginx --image=nginx:1.14 --port=80 --replicas=3
 
kubectl get pods
kubectl get all

3.2 发布kubectl expose命令

●将资源暴露为新的Service

kubectl expose --help
 
//为deployment的nginx创建service, 并通过Service的80端口转发至容器的80端口上,Service的名称为nginx-service, 类型为NodePort
kubectl expose deployment nginx --port=80 --target-port=80 --name=nginx-service --type=NodePort 

-----------------------------------------------
Kubernetes之所以需要Service, 一方面是因为Pod的IP 不是固定的(Pod可能会重建),另一-方面则是因为- -组Pod实例之间总会有负载均衡的需求。

Service通过label Selector实现的对一组的Pod的访问。

对于容器应用而言,Kubernetes 提供了基于VIP (虚拟IP)的网桥的方式访问 Service, 再由Service 重定向到相应的Pod。

service的类型:

●ClusterIP:提供一个集群内部的虚拟IP以供Pod访问( service默认类型)

●NodePort:在每个Node.上打开一个端口以供外部访问,Kubernetes将会在每个Node.上打开一个端口并且每个Node的端口都是一样的,通过NodeIP:NodePort的方式Kubernetes集群外部的程序可以访问Service。

注:每个端口只能是一种服务,端口范围只能是30000-32767

●LoadBalancer:通过外部的负载均衡器来访问,通常在云平台部署LoadBalancer还需要额外的费用
-----------------------------------------------

(1)查看pod网络状态详细信息和Service暴露的端口

kubectl get pods,svc -o wide

(2)查看关联后端的节点

kubectl get endpoints

(3)查看service 的描述信息

kubectl describe svc nginx

(4)在node01 节点上操作,查看负载均衡端口

yum install ipvsadm -y
ipvsadm -Ln

(5)外部访问的IP和端口

TCP 192.168.2.200:30866 rr

(6)pod集群组内部访问的IP和端口

TCP 10.244.1.16:80 
    10.244.2.15:80 
    10.244.2.16:80

(7)在node02 节点上操作,同样方式查看负载均衡端口

yum install ipvsadm -y
ipvsadm -Ln

(8)在master01操作 查看访问日志

kubect1 logs nginx-cdb6b5b95-fjm2x
kubectl logs nginx-cdb6b5b95-g28wz
kubectl logs nginx-cdb6b5b95-x4m24

3.3 更新kubect1 set

(1)更改现有应用资源一些信息

kubectl set --help 

(2)获取修改模板

kubect1 set image --he1p
Examp1es:
# Set a deployment's nginx container image to 'nginx:1.9.1', and its busybox
container image to 'busybox'
kubectl set image deploynent/nginx busybox=busybox nginx=nginx:1.9.1  

(3)查看当前nginx 的版本号

curl -I http://192.168.2.66:30866

(4)将nginx 版本更新为1.15版本

kubect1 set image deployment/nginx nginx=nginx:1.15

(5)处于动态监听pod状态,由于使用的是滚动更新方式,所以会先生成--个新的pod,然后删除--个旧的pod,往后依次类推

kubectl get pods -w  

(6)再看更新好后的Pod的ip会改变

kubectl get pods -o wide

3.4 回滚kubectl rollout

(1)对资源进行回滚管理

kubect1 rollout --he1p 

(2)查看历史版本

kubectl rollout history deployment/nginx

(3)执行回滚到上一个版本

kubectl rollout undo deployment/nginx

(4)执行回滚到指定版本

kubectl rol1out undo deployment/nginx --to-revision=1

(5)检查回滚状态

kubectl rollout status deployment/nginx

3.5 删除kubectl delete

(1)删除副本控制器

kubectl delete deployment/nginx

(2)删除service

kubectl delete svc/nginx-service
 
kubectl get all

 

4、金丝雀发布(Canary Release)——陈述式管理方法

        Deployment控制器支持自定义控制更新过程中的滚动节奏,如“暂停(pause)”或“继续(resume)”更新操作。

        比如等待第一批新的Pod资源创建完成后立即暂停更新过程,此时,仅存在一部分新版本的应用,主体部分还是旧的版本。然后,再筛选一小部分的用户请求路由到新版本的Pod应用,继续观察能否稳定地按期望的方式运行。

        确定没问题之后再继续完成余下的Pod资源滚动更新,否则立即回滚更新操作。这就是所谓的金丝雀发布。

1、更新deployment的版本,并配置暂停deployment

kubectl set image deployment/nginx nginx=nginx:1.16 && kubectl rollout pause deployment/nginx
 
kubectl rollout status deployment/nginx                #观察更新状态

2、监控更新的过程,可以看到已经新增了一个资源,但是并未按照预期的状态去删除一个旧的资源, 就是因为使用了pause暂停命令

kubectl get pods -w

3、确保更新的pod没问题了,继续更新

kubectl rollout resume deployment/nginx

4、查看最后的更新情况

kubectl get pods -W
 

三、声明式管理方法

1.适合于对资源的修改操作

2.声明式资源管理方法依赖于资源配置清单文件对资源进行管理

        资源配置清单文件有两种格式: yaml (人性化,易读),json (易于api接口解析)

3.对资源的管理,是通过事先定义在统一资源配置清单内,再通过陈述式命令应用到k8s集群里

4.语法格式: kubectl create/app1y/delete -f xxxx.yaml

kubectl create 和 kubectl apply区别

kubectl create -f xxx.yaml 
(一次性的)
 
kubectl apply -f xxx.yaml 
(创建资源没法更新)

如果yaml文件中的kind值为deployment,那么上面这两个命令都可以创建一个deployment,生成相应数量的pod

区别:

kubectl create:

(1)kubectl create命令,是先删除所有现有的东西,重新根据yaml文件生成新的。所以要求yaml文件中的配置必须是完整的

(2)kubectl create命令,用同一个yaml 文件执行替换replace命令,将会不成功,fail掉。

kubectl apply:

kubectl apply命令,根据配置文件里面列出来的内容,升级现有的。所以yaml文件的内容可以只写需要升级的属性

1、查看资源配置清单

kubectl get deployment nginx -o yaml

2、解释资源配置清单

kubectl explain deployment.metadata
 
kubectl get service nginx -o yaml
kubectl explain service.metadata

service是相同的方法查看,省略图  

//修改资源配置清单并应用

离线修改:

修改yaml文件,并用kubectl apply -f xxxx.yaml文件使之生效
注意:当apply不生效时, 先使用delete清除资源,再apply创建资源

kubectl get service nginx -o yaml > nginx-svc.yaml
vim nginx-svc.yaml
#修改port: 8080
kubectl delete -f nginx-svc.yaml
kubectl apply -f nginx-svc.yaml
kubectl get svc

在线修改:
直接使用kubectl edit service nginx
在线编辑资源配置清单并保存退出即时生效(如port:888)
PS:此修改方式不会对yaml文件内容修改

//删除资源配置清单
陈述式删除:

kubectl delete service nginx 

声明式删除:

kubectl delete -f nginx-svc.yaml

 2、声明式资源管理办法

通过yaml资源配置清单文件在实现资源的管理

kubectl create/apply -f *.yaml

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

k8s——kubectl 的相关文章

  • openFileOutput 在单例类中无法正常工作 - 想法/解决方法?

    作为一名 Android 开发新手 我遇到了一些奇怪的问题 我想创建一个类 它方法其他类 活动 任何可以用于以某种特殊方式处理文件的类 假设为了简单起见 我们将记录一些内容 如果我在活动中执行以下操作 例如在 OnClick 侦听器中 则一
  • 如何重复一段文本中的每个字母?爪哇语

    就像在口吃中一样 如果文本为 dean 并且乘数为 3 则结果将是 dddeeeaaannn 由提供的乘数指定的次数 public static void repeatLetters String text dean int n 3 Str
  • JAX-WS 入门 [关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 有人可以推荐一些关于 JAX WS 入门的好教程吗 使用各种工具 如 wsgen 等 您可以从这里开始 通过 Java SE 6 平台介绍
  • Spring Data Jpa OneToMany 同时保存子实体和父实体?

    这是我的父实体 注意 为了简洁起见 删除了 getter setter lombok 注释 Entity public class Board Id GeneratedValue strategy GenerationType IDENTI
  • Jenkins 未显示 Maven 编译器错误

    在 Jenkins 中构建多模块 maven 3 项目时 如果出现构建错误 我们会收到一条神秘消息 表明 Maven 编译器插件失败 这在上周才刚刚开始发生 INFO BUILD FAILURE INFO INFO Total time 1
  • 如何杀死 Java Future?

    我正在开发的服务使用 Future 来并行运行多个任务 每个任务最多可能需要一分钟才能完成 然而 外部库似乎有问题 因为在某些情况下 2 的时间 它不会返回 在这些情况下 我想给出 2 分钟的等待时间 如果还没有返回 我想杀死 future
  • Java:一种将 Mime(内容)类型与 CommonsMultipartFile 中的文件扩展名相匹配的方法

    在我的公司 出于额外原因 我需要将 mime 类型与文件扩展名进行比较 我有一个CommonsMultipartFile 我正在尝试找出进行这种比较的最佳方法 我见过一个MimetypesFileTypeMap 但不确定这是否适用于此 我试
  • Android 信号 11 (SIGSEGV),代码 1 (SEGV_MAPERR) libwebviewchromium.so

    对于 android 4 4 我多次收到 Native crash at system lib libwebviewchromium so 错误 以下是设备包括 Xperia Z1 SO 01F 16 30 2 Galaxy Tab4 7
  • 传递自定义类型查询参数

    如何接受自定义类型查询参数 public String detail QueryParam request final MYRequest request 上面的行在启动服务器时出现错误 jersey server model ModelV
  • 是否可以使用 Apache Tika 提取表信息?

    我正在寻找 pdf 和 MS Office 文档格式的解析器 以从文件中提取表格信息 当我看到 Apache Tika 时 正在考虑编写单独的实现 我能够从任何这些文件格式中提取全文 但我的要求是提取表格数据 我希望有 2 列采用键值格式
  • Docker 容器中的并行代码执行

    我有一个通过 URLslist 抓取数据的脚本 该脚本在 docker 容器中执行 我想在多个实例中运行它 例如 20 个 为此 我想使用docker compose scale worker 20并将 INDEX 传递给每个实例 以便脚本
  • Concourse CI 找不到 kubernetes 秘密

    当运行程序尝试检索资源时 我收到以下错误 checking failed Expected to find variables git 我的资源看起来类似于 name resource repo type git source uri ht
  • Java 8:如何创建毫秒、微秒或纳秒的 DateTimeFormatter?

    我需要创建格式化程序来解析具有可选的毫秒 微米或纳秒分数的时间戳 例如 对于我的需求 我看到以下机会 DateTimeFormatter formatter new DateTimeFormatterBuilder append DateT
  • 在 Kotlin 中声明静态属性?

    My Java code public class Common public static ModelPengguna currentModelPengguna public class Common companion object v
  • 添加 char 和 int

    据我了解 字符是一个字符 即一个字母 一个digit 标点符号 制表符 空格或类似的东西 因此 当我这样做时 char c 1 System out println c 输出 1 正是我所期望的 那么为什么当我这样做时 int a 1 ch
  • 如何在一次操作中使用 Thymeleaf 检查 null 和空条件?

    有什么方法可以检查 Thymeleaf 中的 null 和empty 条件吗 方法一 1 variable1 variable2 variable3 2 variable null 3 variable 如果我们结合两个条件 例如 vari
  • 线程数组?

    所以我在理解如何避免线程的顺序执行时遇到了问题 我试图创建一个线程数组并在单独的循环中执行 start 和 join 函数 这是我现在拥有的代码示例 private static int w static class wThreads im
  • 用于生成 ISO 文件的 Maven 插件

    有没有可以生成ISO镜像的maven插件 我需要获取一些模块的输出 主要是包含 jar 的 zip 文件 并将它们组合成一个 ISO 映像 Thanks 现在有一个 ISO9660 maven 插件可以完成这项工作 https github
  • 亚马逊 Linux - 安装 openjdk-debuginfo?

    我试图使用jstack在 ec2 实例上amazon linux 所以我安装了openjdk devel包裹 sudo yum install java 1 7 0 openjdk devel x86 64 但是 jstack 引发了异常j
  • Heroku 码头部署

    我正在关注这篇文章https devcenter heroku com articles container registry and runtime https devcenter heroku com articles containe

随机推荐

  • Node.js后端开发 - 进阶篇 #8 express框架之路由模块的封装1

    目录 一 前言 二 路由模块的封装 1 初始化项目 安装express框架 1 npm init y 初始化项目 生成package json文件 2 npm init y 和 npm init 区别 3 安装 express 框架 生成
  • 卸载 SQL Server Management Studio 的操作工具

    我们今天是要和大家一起讨论的是卸载 SQL Server Management Studio 时所要用到的实际操作工具 以及对实现卸载 SQL Server Management Studio 的实际操作步骤的具体描述 以下就是文章的主要内
  • Windows下 Cmake 没有生成makefile文件

    Windows下 Cmake 没有生成makefile文件 不是为了生成解决方案的 针对指令操作 1 主要是因为编译器选择的问题 很有可能选择到了vs的编译器MSVC 了导致生成了解决方案 2 如下操作 使用cmake G Unix Mak
  • 2023年最好用的办公AI工具,让你工作效率提升10倍!

    2023年是AI工具大爆发的一年 在效率办公领域 同样涌现出了很多优秀的AI办公工具 小编亲测了几款 都是宝藏好用的App 以下排名不分先后 一起来看看吧 AI办公工具哪个好 GitMind Notion AI 酷表ChatExcel 通义
  • 计算机老师副业能做什么,教师除了本职工作,还能做哪些副业?

    原标题 教师除了本职工作 还能做哪些副业 本文来源于微信公众号 教师帮 作者 小磊哥 图 互联网 如有转载 请联系并注明原出处 不知老师在学校有没有发现这么一种情况 当你正在为这个月的工资怎么分配而发愁的时候 坐在你身边的同事却春风得意 好
  • 模糊控制器 Matlab 源码程序设计

    模糊控制器 Matlab 源码程序设计 模糊控制是指在不确定 复杂的环境中 通过将自然语言转为数学形式 使用一定的逻辑运算来处理模糊信息 从而实现对系统的控制 在实际应用中 模糊系统已被广泛应用于各种领域 如自动控制 图像处理 数据挖掘等方
  • 软件测试用例编写方法

    边界值分析方法 概念 边界值其实就是一种黑盒测试方法 边界值本质上就是有效等价类和无效等价类的边界 1 边界范围节点 边界值的三个概念 上点 边界值上面的这个点 就是上点 正好等于 内点 有效等价类中的任意一个点 区间范围内的数据 离点 边
  • 改变数据类型

    int 是32 long 是64 numpy改变 pytorch改变 np th list 互换
  • CCF-CSP真题《202305-1 重复局面》思路+python,c++满分题解

    想查看其他题的真题及题解的同学可以前往查看 CCF CSP真题附题解大全 试题编号 202305 1 试题名称 重复局面 时间限制 1 0s 内存限制 512 0MB 问题描述 题目背景 国际象棋在对局时 同一局面连续或间断出现3次或3次以
  • 如何实现概率性事件

    游戏中经常会遇到概率性的问题 比如装备升级的成功率 合成宝石的成功率 洗装备时出现随机属性条数的概率等 这些概率性事件具体是怎么实现的呢 在网上看了一些相关的文章 总结一下 首先需要了解两个函数rand 和srand 下面是百科里面的解释
  • 如何存储Ajax请求的响应值

    如何存储Ajax请求的响应值 一 背景 二 代码部分 三 总结 一 背景 开发者使用Ajax请求网络 获取到了返回的结果 但开发者不想将回调函数写的过于冗长 因此希望将Ajax请求的返回值存储到一个变量中 方便后期取用 二 代码部分 代码部
  • Qt简介以及工程创建

    Qt是一种跨平台应用程序和UI开发框架 只需要一次性开发应用程序 可应用于不同的系统 Qt不是一个严格的前后端 而是一种框架 Qt Creator是一种全新跨平台 Qt IDE集成开发环境 可以单独使用 也可以与Qt库和开发工具组成一套完整
  • Unhandled exception at 0x00291422 in x.exe: 0xC0000005: Access violation writing location 0x37ACCE08

    源码如下 include
  • 线性表顺序存储の介绍、应用 与 实践(第二章: 线性表 )

    一 线性表的介绍 线性表 线性表 linear list 是n个具有相同特性的数据元素的有限序列 线性表是一种在实际中广泛使用的数据结构 常见的线性表 顺序表 链表 栈 队列 字符串 线性表在逻辑上是线性结构 也就说是连续的一条直线 但是在
  • 代码覆盖度工具OpenCppCoverage(cpp)、EclEmma(java)、Coverage(python)使用

    一 OpenCppCoverage cpp OpenCppCoverage是一个运行在windows上的程序 其不是在编译时进行插桩 而是在运行时 因此保证了代码和测试的一致性 参考文档 https github com OpenCppCo
  • 【c/c++】#pragma once 与 #ifndef 的区别解析

    原文地址 http blog csdn net hkx1n article details 4313303 作用 为了避免同一个文件被include多次 C C 中有两种方式 一种是 ifndef方式 一种是 pragma once方式 在
  • 智能指针使用陷阱

    智能指针使用陷阱 1 不能把一个原生指针交给多个智能指针管理 int x new int 10 unique ptr
  • android同步目录,如何使用FolderSync在安卓手机上同步文件夹到坚果云?

    FolderSync 是一款Android 端的文件同步工具 可以将手机中的文件自动同步到云端空间或者PC端 支持包括 FTP WebDAV Dropbox Amazon S3 FTP FTPS SFTP WebDAV等 可以使用WebDA
  • 几种图像的分割方法汇总

    图像分割指的是将原图像按照灰度 纹理 颜色 形状等划分成不同的区域 因此 在同一个区域间 呈现出具备一些相同的特点 而在不同的区域间 分割出的各个图像会有一定的差别 1 基于阈值的分割方法 基于阈值的分割方法是按照原图像的灰度特征划分出一个
  • k8s——kubectl

    目录 一 k8s管理操作方法 二 陈述式资源管理方法 1 基本信息查看 1 1 查看k8s版本信息 1 2 查看资源对象简写 1 3 查看集群信息 1 4 配置kubectl自动补全 1 5 node节点查看日志 2 基本信息查看 2 1