我的编程空间,编程开发者的网络收藏夹
学习永远不晚

docker笔记22-k8s资源清单定义入门

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

docker笔记22-k8s资源清单定义入门

资源分类:    

    1)workload型资源:service,pod,Redeployment(控制器,我们很少直接操作pod,而是通过控制器来操作Pod)、ReplicaSet、StatefilSet、Job、Cronjob

    2)服务发现及服务均衡资源型资源:Service、Ingress

    3)配置与存储型资源:Volume、CSI(容器存储接口,可以扩展各种第三方的存储卷)、ConfigMap、Secret、DownwardAPI

    4)集群级资源:Namespace、Node、Role、rolebinding、clusterrolebinding

    5)元数据型资源:HPA、podtemplate、limitrange(限制资源的如cpu、内存等)

查看pod的yaml格式清单

[root@master ~]# kubectl get podsNAME                          READY     STATUS             RESTARTS   AGEclient                        1/1       Running            0          17hmyapp-fcc5f7f7c-4x2p7         0/1       ImagePullBackOff   0          12hmyapp-fcc5f7f7c-dnkdq         0/1       ImagePullBackOff   0          12hmytomcat-5f8c6fdcb-7t5s2      1/1       Running            0          11hmytomcat-5f8c6fdcb-lhcsc      1/1       Running            0          12hmytomcat-5f8c6fdcb-rntrg      1/1       Running            0          12hnginx-deploy-5b595999-fpm8x   1/1       Running            0          12h
[root@master ~]# kubectl get pods mytomcat-5f8c6fdcb-lhcscNAME                       READY     STATUS    RESTARTS   AGEmytomcat-5f8c6fdcb-lhcsc   1/1       Running   0          12h
[root@master ~]# kubectl get pods mytomcat-5f8c6fdcb-lhcsc -o yamlspec: #规格、特性,用户期望的状态  containers:  tolerations: #容忍度status:#显示当前资源的当前状态  conditions:

创建资源的方法

    apiserver仅接收JSON格式的资源定义。我们可以使用yaml格式提供配置清单,因为ymal格式是以缩进的方式来写的,更利用人们的理解。我们写完ymal格式的配置清单后,apiserver可以自动将其转为json,然后再提交。

    另外,我们使用命令kubectl run,其最终也是自动转为json格式的资源定义了。

    大部分的的资源的配置清单包含:

    1)apiVersion:表示属于哪个api群组和版本,可以通过命令 kubectl api-versions来看,显示方式为group/version

    2)Kind:资源类别,有pod、deloyment类别等

    3)metadata:元数据,包括:

        a) name:在同一资源下name是必须唯一的;

        b) namespace

        c) labels

        d) annotations:资源注解

        e)uid

        f) resourceversion:

        g) OwnerReferences

        h) selfLink:每个资源引用的PATH,格式为/api/GROUP/VERSION/namespaces/NAMESPACE/TYPE/NAME

    4) spec,定义用户期望的目标状态(disired state)

    5)status:表示当前状态,让当前状态向期望的目标状态靠近,本字段有k8s集群维护。

查看资源清单的帮助

    由于spec的字段很多,我们背不下来了,所以可以如下查看帮助。

[root@master ~]#  kubectl explain pods

    看medadata下有哪些字段可以用:

[root@master ~]#  kubectl explain pods.metadata

    看spec下有哪些字段可以用:

[root@master ~]#  kubectl explain pods.spec

    看spec.containers下有哪些字段可以用:

[root@master ~]#  kubectl explain pods.spec.containers

例子-用ymal创建pod

    用yaml格式创建一个pod

[root@master ~]# mkdir manifests[root@master ~]# cd manifests/
[root@master manifests]# cat pod-demo.yaml apiVersion: v1kind: Podmetadata:  name: pod-demo  namespace: default  labels:    app: myapp  #kv格式的,也可以用花括号表示    tier: frontend #定义所属的层次spec:  containers:   - name: myapp  #前面的-号表示这是一个列表格式的,也可以用中括号表示    image: tomcat   - name: busybox    image: busybox:latest    command:    - "/bin/sh"    - "-c"    - "echo $(date) >> /usr/share/nginx/html/index.html; sleep 5"   #以上命令也可以写作:command: ["/bin/sh","-c","sleep 3600"]
[root@master manifests]# kubectl create -f pod-demo.yaml pod/pod-demo created
[root@master manifests]# kubectl get podsNAME                          READY     STATUS             RESTARTS   AGEpod-demo                      2/2       Running            1          33s
[root@master manifests]#kubectl describe pods pod-demo 可以看到一个pod里面跑了两个容器,一个是busybox,一个是tomcat

查看pod里面容器的日志

[root@master manifests]# kubectl logs pod-demo myapp

说明:pod-demo是上面我们创建的pod名字,myapp是pod里面容器的名字。

进入运行中的容器

[root@master manifests]# kubectl exec -it pod-demo -c myapp -- /bin/bashroot@pod-demo:/usr/local/tomcat#

-c:自动容器名字;pod-demo是我们自己创建的容器名字。

删除配置清单定义的资源

[root@master manifests]# kubectl delete -f pod-demo.yaml pod "pod-demo" deleted

用命令run pod和用资源清单创建的pod区别

    我们用命令run一个pod是需要创建一个控制器deployment的,所以删除这样的pod后,控制器deployment会自动新建一个,怎么也删不掉。

    而我们用配置清单创建的pod,没有控制器deployment,是一个裸pod,所以一删除就没了,这个挺好。

    命令创建的:

[root@master ~]# kubectl  expose deployment nginx-deploy --name=nginx --port=80 --target-port=80 --protocol=TCP

    资源清单创建的:

[root@master manifests]# kubectl create -f pod-demo.yaml pod/pod-demo created

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

docker笔记22-k8s资源清单定义入门

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

docker笔记22-k8s资源清单定义入门

资源分类: 1)workload型资源:service,pod,Redeployment(控制器,我们很少直接操作pod,而是通过控制器来操作Pod)、ReplicaSet、StatefilSet、Job、Cronjob
2023-06-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录