码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 云原生K8S------K8S管理工具kubectl详解(一)


    目录

    一,陈述时管理

    1.1 陈述式资源管理方式

    1.2 K8S相关信息查看

    查看版本信息

    查看节点信息

    查看资源对象简写

    查看集群信息

     配置kubectl自动补全

    查看日志

     基本信息查看

    查看master节点状态

     查看命名空间

    1.3 命名空间操作

     1.3.2 创建命名空间

    1.3.3 删除命名空间

    1.4 deployment/pod操作

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

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

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

     1.4.4 登录容器

     1.4.5 删除(重启)pod资源

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

     1.4.7 扩容、

     1.4.8 缩容

    1.4.9 删除副本控制器

    1.4.10 定义自动扩容,缩容规则

    1.5 增加,删除label

    1.51,增加label

     1.52,删除label

    ​编辑

     二,声明式管理

    1,声明式管理方法

    2,查看资源配置清单

     3,解释资源配置清单

     4,修改资源配置清单并应用

    4.1 离线修改

    4.1.1 修改yaml文件


    一,陈述时管理

    1.1 陈述式资源管理方式

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

    1.2 K8S相关信息查看

    查看版本信息

    kubectl version

    查看节点信息

    kubectl get node

    查看资源对象简写

    查看集群信息

    kubectl cluster-info

     配置kubectl自动补全

    source <(kubectl completion bash)

    可通过TAB键实现命令补全,建议将其写入/etc/profile

    一般用的比较少

    查看日志

    journalctl -u kubelet -f

     基本信息查看

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

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

    resource可以是具体资源名称,如“pod nhinx-xxx”;也可以是资源类型,如“pod,node,svc,deploy”多种资源使用逗号间隔;或者all(仅显示包含app标签,并不完整)

    1. -all-namespace 或者-A:标识显示所有命令空间
    2. -show-labels: 显示所有标签
    3. -l app:仅显示标签为app的资源
    4. -l app=nginx:仅显示包含app标签,且值为nginx的资源。

    查看master节点状态

    1. kubectl get componentstatuses
    2. #cpmponentstatuses可以缩写成cs
    3. kubectl get cs

     查看命名空间

    1.3 命名空间操作

    1.3.1 查看default命名空间的所以资源

    kubectl get all [-n default]
    

     由于deafult为缺省空间,当不指定命名空间时默认查看default命名空间

     1.3.2 创建命名空间

    kubectl create ns cxk

    1.3.3 删除命名空间

    kubectl delete  ns cxk

    1.4 deployment/pod操作

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

    kubectl create deployment nginx-test --image=nginx -n cxk

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

    kubectl describe deployment nginx-test -n cxk

    kubectl describe pod nginx-test -n cxk
    

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

     1.4.4 登录容器

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

    kubectl exec  -it nginx-test-795d659f45-6528h bash -n cxk

     1.4.5 删除(重启)pod资源

    由于存在deployment之类的副本控制器,删除pod也会被重新拉取起来

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

    kubectl delete pod [] -n [] --force --grace-period=0
    

    grace-period表示过渡存活期,默认30s,在删除pod之前允许pod慢慢终止其上的容器进程,从而优雅的退出,0表示立即终止pod

     1.4.7 扩容、

    kubectl scale deployment nginx-test --replicas=3 -n cxk

     1.4.8 缩容

    kubectl scale deployment nginx-test --replicas=2 -n cxk
    

    1.4.9 删除副本控制器

    kubectl delete deployment nginx-test -n cxk

    1.4.10 定义自动扩容,缩容规则

    使用deployment “foo” 设定,使用默认的自动伸缩策略,指定目标cpu使用率,使其pod数量在2.10之间

    1. kubectl autoscale deployment foo --min=2,--max=10
    2. 使用RC'foo' 设定,使其pod的数量介于1-5之间,cpu使用率维持在80%
    3. kubectl autoscale rc foo --max=5 --cpu-rercent=80

     自动扩容,缩容触发条件

    定义最大最小pod数量

    定义扩容条件:往往和pod使用的基础资源百分比相关,例如使用到cpu资源80%的时候触发扩容

                             80% 不是指node节点的80%,而是指pod内limint上限的80%

    1.5 增加,删除label

    1.51,增加label

    kubectl label deploy nginx-test version=nginx1.14
    

     1.52,删除label

    kubectl label deploy nginx-test version-
    

     二,声明式管理

    1,声明式管理方法

    1. 适合于对资源的修改操作
    2. 声明式资源管理方法依赖于资源配置清明文件对资源进行管理
    3. 资源配置清单文件有两种格式:yaml(人性化,易读),json(易于api接口解析)
    4. 对资源的观念里,是通过实现定义在同一资源配置清单内,再通过陈述式命令应用到k8s集群里
    5. 语法格式:kubectl create/apply/delete -f -o yaml
       

    2,查看资源配置清单

    kubectl get deploy/nginx-test -o yaml
    

    kubectl get service nginx-service -o yaml
    

     3,解释资源配置清单

    kubectl explain deployment.metadata
    

    kubectl explain service.metadata
    

     4,修改资源配置清单并应用

    4.1 离线修改

    4.1.1 修改yaml文件

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

    kubectl get service nginx-service -o yaml > nginx-svc.yaml
    

  • 相关阅读:
    从JVM角度理解Java并发(下)
    Advanced Installer使用(亲测可用)
    11-01课堂
    07-Go语言中map数据结构用法
    QT国际化,语言翻译
    List<T>范型的使用
    npm 执行命令时报错npm ERR! code ERESOLVE npm ERR! ERESOLVE could not resolve
    技术分享 | 测试平台开发-前端开发之数据展示与分析
    PyQt5学习笔记--摄像头实时视频展示、多线程处理、视频编解码
    git@github.com: Permission denied (publickey).
  • 原文地址:https://blog.csdn.net/m0_54594153/article/details/127636381
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号