k8s中yaml文件的编写

news2025/1/22 13:05:29

目录

1.编写pod.yaml

2.编写deploment.yaml

3.编写service.yaml关联创建的pod

4.总结获取K8S资源配置清单文件模板方法

方法1:根据现有资源导出yaml文件修改配置,重新创建

方法2:根据现有资源,进入其配置中,复制模板,再进行创建

方法3:通过--dry-run选项模拟运行创建资源的命令获取

方法4:手写yaml配置文件,可以根据 kubectl explain 命令获取资源的字段信息

5.补充


1.编写pod.yaml

vim demo1-pod.yaml
apiVersion: v1
kind: Pod
metadata:
  name: scj-pod
  namespace: xy101
  labels:
    app: nginx
    mylove: tangjun
    myclass: xy101
spec:
  containers:
  - name: nginx
    image: nginx:1.20
    ports:
    - containerPort: 80
      name: http
      protocol: TCP
    env:
    - name: mylove
      value: tangjun

各行详细介绍

使用kubectl explain pods可查看到编写pod的一级标题
apiVersion: apps/v1		#指定api版本标签
kind: Deployment		#定义资源的类型/角色,deployment为副本控制器,此处资源类型可以是Deployment、Job、Ingress、Service等
metadata:					#定义资源的元数据信息,比如资源的名称、namespace、标签等信息

spec:					#定义deployment资源需要的参数属性,诸如是否在容器失败时重新启动容器的属性

metadata:					#定义资源的元数据信息,比如资源的名称、namespace、标签等信息
kubectl explain pods.metadata  进一步查看metadata所包含内容
书写格式:
<string>       字符串           字段: 字符串      字段: "字符串"      字段: '字符串'
<map[string]string>    映射(值是一个或多个键值对)   字段:
                                                        key1: value1
                                                        key2: value2

spec:					#定义deployment资源需要的参数属性,诸如是否在容器失败时重新启动容器的属性
kubectl explain pods.spec  #进一步查看spec
containers	<[]Object> -required-  #-required-表示必备字段;<[]Object>表示字符串列表      
格式
<[]Object>字段:             字段: ["值1", "值2"]
                                - 值1
                                - 值2

containers:				#定义容器属性

kubectl explain pods.spec.containers  #进一步查看containers字段


kubectl explain pods.spec.containers.ports

kubectl explain pods.spec.containers.env

kubectl apply -f demo1-pod.yaml   #创建pod
kubectl get pods -n xy101   #查看pod
kubectl describe -n xy101 pod scj-pod   #可查看调度创建容器的具体过程


kubectl get -n xy101 pod --show-labels   #查看标签
kubectl exec -n xy101 -it scj-pod sh  #进入容器查看env

2.编写deploment.yaml

vim demo2-deploy.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: scj-deploy
  namespace: xy101
  labels:
    app: nginx
    mylove: tangjun
spec:
  replicas: 5
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.20
        ports:
        - containerPort: 80
          name: http
          protocol: TCP
        env:
        - name: mylove
          value: tangjun
        - name: yourlove
          value: scj

查看编写deployment.yaml文件的第一字段

kubectl explain deployment   #查看编写deployment的第一字段

查看第一字段下metadata和spec下的字段

kubectl explain deployment.metadata  #可根据此命令进一步查看metadata字段
metadata:                #其中包含三大项必不可少,name、namespace、labels
  name: scj-deploy
  namespace: xy101
  labels:
    app: nginx
    mylove: tangjun

kubectl explain deployment.spec #进一步查看spec的字段​​​​​​​


查看spec下selector的字段

kubectl explain deployment.spec.selector  #查询selector的字段

matchLabels:		#定义匹配标签

查看spec下template的字段

kubectl explain deployment.spec.template   #查看spec中template字段下的字段
metadata   #定义pod元数据  通常主要定义labels,labels的值需要与标签选择器的值一致
spec   #定义pod属性


查看template下spec的字段

kubectl explain deployment.spec.template.spec   #查看template下spec字段
containers	<[]Object> -required-   #必选字段

kubectl explain deployment.spec.template.spec.containers  #进一步查看spec下containers 字段

kubectl explain deployment.spec.template.spec.containers.ports   #进一步查看containers下ports字段

查看spec下containers中的字段

kubectl explain deployment.spec.template.spec.containers



查看containers下ports的字段

kubectl explain deployment.spec.template.spec.containers.ports

查看containers下的env字段

kubectl explain deployment.spec.template.spec.containers.env


创建deployment控制器

kubectl apply -f demo2-deploy.yaml
kubectl get -n xy101 all

3.编写service.yaml关联创建的pod

apiVersion: v1
apiVersion: v1
kind: Service
metadata:
  name: scj-svc
  namespace: xy101
  labels:
    app: nginx
    mylove: tangjun
spec:
  selector:
    app: nginx
  type: NodePort
  ports:
  - port: 8080
    targetPort: 80

查看编写svc.yaml文件的第一字段

kubectl explain svc

metadata三要素1.name2.namespace3.labels

设置spec下的字段

kubectl explain svc.spec



进一步查看spec下ports的字段

kubectl explain svc.spec.ports


创建service

kubectl apply -f demo3-svc.yaml
kubectl get -n xy101 svc
kubectl describe -n xy101 endpoints scj-svc
kubectl get -n xy101 pod -o wide

如何固定nodeport、clusterip

kubectl explain svc.spec.ports   #查询指定nodeport的字段,于ports下
kubectl explain svc.spec    #查询指定clusterip的字段,于svc下的spec中

kubectl apply -f demo3-svc.yaml
kubectl get -n xy101 svc

kubectl apply -f demo3-svc.yaml 
kubectl get -n xy101 svc

4.总结获取K8S资源配置清单文件模板方法

方法1:根据现有资源导出yaml文件修改配置,重新创建

kubectl get -n xy101 svc scj-svc -o yaml > demo4.yaml
vim demo4.yaml
只保留常用配置,删除多余的,配置,进行修改创建即可

方法2:根据现有资源,进入其配置中,复制模板,再进行创建

kubectl edit -n xy101 svc scj-svc2   
即可复制其中的配置,获取模板

方法3:通过--dry-run选项模拟运行创建资源的命令获取

kubectl create|run|expose -n <命名空间> <资源类型> <资源名称> [参数选项] --dry-run=client -o yaml > XXX.yaml


kubectl create -n xy101 deployment deploy-tan --image=soscscs/myapp:v1 --port=80 --replicas=3 --dry-run=client   #创建资源的结尾添加--dry-run选项模拟运行创建资源,此时不会创建资源

kubectl create -n xy101 deployment deploy-tan --image=soscscs/myapp:v1 --port=80 --replicas=3 --dry-run=client -o yaml > tan-deploy.yaml  #导出yaml文件,即可获取配置模板文件

方法4:手写yaml配置文件,可以根据 kubectl explain 命令获取资源的字段信息

5.补充

1.什么是external-traffic-policy

kubectl explain svc.spec  #存在于 svc.spec中

在k8s的Service对象(申明一条访问通道)中,有一个“externalTrafficPolicy”字段可以设置。有2个值可以设置:Cluster或者Local。

1)Cluster表示:流量可以转发到其他节点上的Pod。

2)Local表示:流量只发给本机的Pod。

图示:

2.k8s的service如何确保客户端的tcp消息每次都发给同一个pod?

设置Service的sessionAffinity为 ClientIP. 这样同一个client的请求会被kube-proxy转发到同一个Pod。
sessionAffinity 默认是None,客户端的请求被kube-proxy按照RR或Random算法转发到service的pod set,不能保证每次发到同一个Pod。

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

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

相关文章

Go语言实现多协程文件下载器

文章目录 前言流程图主函数下载文件初始化分片下载worker分发下载任务获取下载文件的大小下载文件分片错误重试项目演示最后 前言 你好&#xff0c;我是醉墨居士&#xff0c;最近在开发文件传输相关的项目&#xff0c;然后顺手写了一个多协程文件下载器&#xff0c;代码非常精…

Cxx primer-chap12-Dynamic Memory

目前我们使用的对象都是语言本身代替我们管理其生命周期和作用域&#xff0c;例如global object、局部的自动变量和局部的static变量&#xff0c;除此之外&#xff0c;语言也允许我们创建动态分配的对象&#xff08;即运行时创建的对象&#xff09;&#xff1a;不同类型的对象&…

SpringCloud概述和基本工程搭建

目录 1.认识微服务 1.1单体架构 1.2集群和分布式架构 1.3微服务架构 1.4微服务的优势 2.微服务解决方案-Spring Cloud 2.1什么是Spring Cloud 2.2Spring Cloud Alibaba 2.3SpringCloud实现对比 3.服务拆分原则 3.1单一职责原则 3.2服务自治原则 3.3单向依赖原则 …

前端:Vue

一、引入 Vue是一套前端框架&#xff0c;免除javaScript中的DOM操作&#xff0c;简化书写。基于MVVM思想&#xff0c;实现数据的双向绑定&#xff0c;将编程的关注点放在数据上。 框架&#xff1a;是一个半成品软件&#xff0c;是一套可重用的、通用的、软件基础代码模型。基于…

C#初级——字典Dictionary

字典 字典是C#中的一种集合&#xff0c;它存储键值对&#xff0c;并且每个键与一个值相关联。 创建字典 Dictionary<键的类型, 值的类型> 字典名字 new Dictionary<键的类型, 值的类型>(); Dictionary<int, string> dicStudent new Dictionary<int, str…

深度学习-----------数值稳定性

目录 神经网络的梯度数值稳定性的常见两个问题例子&#xff1a;MLP 梯度爆炸梯度爆炸的问题 梯度消失梯度消失的问题 总结模型初始化和激活函数让训练更加稳定让每层的方差是一个常数 权重初始化正向均值和方差正向均值正向方差 反向均值和方差Xavier初始正向和反向的均值和方差…

HTTP:从基础概念到协议机制,详解请求响应与状态保持

文章目录 一、HTTP概述1、HTTP的理解2、HTTP是无状态的协议 二、HTTP协议的过程1、URL&#xff08;统一资源定位符&#xff09;2、客户端3、服务器端 三、HTTP请求与响应1、HTTP请求和响应2、HTTP请求方法3、状态码 四、HTTP报文1、请求报文首部2、响应报文首部3、首部字段 五、…

全网唯一!R语言顶刊配色包TheBestColors

与Matlab相比&#xff0c;R语言在绘图方面有着天然的优势。 比如在配色方面&#xff0c;R语言有各式各样现成的包&#xff0c;按理说配色这种事应该很方便才对。 但实际体验下来&#xff0c;发现似乎不是那么回事。 首先&#xff0c;你很难记住每个包的调用方法以及每种配色…

【autodl】stable-diffusion-3-medium快速部署

sd3m是一个文生图模型&#xff0c;支持英文提示词&#xff0c; 支持自然语言 stable diffusion 3 medium 是一个开源模型&#xff0c;本教程是在autodl上部署modelscope上的sd3模型。下面是运行的webui页面图 配置 充值autodl &#xff0c;并且创建一个服务器&#xff1a;我的…

7.C基础_数组

一维数组 1、数组定义 形式&#xff1a;<数据类型> <数组名>[元素数量]&#xff0c;如&#xff1a;int a[3]; 数组的元素&#xff1a;组成数组的各个变量 注意&#xff1a; 数组中各元素的数据类型要求相同元素数量必须为整数&#xff0c;数组一旦创建&#x…

图片管理组建

父 <template><div style"height: 100%;"><!-- 加载中 --><div class"demo-spin-cols" :style"loading"><Icon type"ios-loading" size18 class"demo-spin-icon-load"></Icon><div…

【Kubernetes】Deployment 的状态

Deployment 的状态 Deployment 控制器在整个生命周期中存在 3 3 3 种状态&#xff1a; 已完成&#xff08;Complete&#xff09;进行中&#xff08;Progressing&#xff09;失败&#xff08;Failed&#xff09; 通过观察 Deployment 的当前特征&#xff0c;可以判断 Deploym…

『 Linux 』线程安全的单例模式,自旋锁与读写锁

文章目录 单例模式懒汉模式与饿汉模式 自旋锁读写锁 单例模式 单例模式是一种创建型设计模式,其主要目的是确保一个类只有一个实例,并提供一个全局访问点来访问该实例; 这在需要严格控制如何及合适访问某个唯一资源型下有一定作用; 单利模式的主要特点为如下: 私有构造函数 单…

使用Dockerfile构建一个包含NVIDIA的PyTorch和Detectron2的镜像

查看Dockerfile 以下是详细的解释&#xff1a; # 使用更具体的标记来固定基础镜像版本&#xff0c;确保环境一致性 FROM nvcr.io/nvidia/pytorch:23.01-py3# 设置工作目录和环境变量 WORKDIR /root ENV DETECTRON2_PATH /root/detectron2# 复制并安装 Detectron2 COPY detect…

YOLOv10模型训练、验证、推理

前言 yolov10关于模型的各种参数其实都写到了一起&#xff08;包括训练、验证和推理的参数&#xff09;&#xff0c;在./ultralytics/cfg/default.yaml中&#xff0c;通过使用这些指令我们可以实现各种所需的操作。 代码地址&#xff1a;https://github.com/THU-MIG/yolov10 …

【Material-UI 组件】Autocomplete 中的 Grouped 功能详解

文章目录 一、组件概述1.1 Grouped 功能介绍1.2 适用场景 二、基础用法2.1 实现 Grouped 功能代码拆解 三、高级配置3.1 自定义组渲染3.2 常见配置 四、最佳实践4.1 数据排序4.2 组标题优化4.3 性能优化4.4 可访问性 五、总结 Grouped 功能使得 Autocomplete 组件能够按特定维度…

Linux系统驱动(三)ioctl函数

文章目录 一、ioctl函数&#xff08;一&#xff09;函数格式&#xff08;二&#xff09;ioctl命令码的组成1. 命令码的组成2. 自己封装命令码2. 内核提供了封装命令码的宏 &#xff08;三&#xff09;使用示例1. 驱动2. 应用 一、ioctl函数 Linux内核开发者想要将数据的读写和…

c++ 21 指针

*像一把钥匙 通过钥匙去找内存空间 间接修改内存空间的值 不停的给指针赋值 等于不停的更改指针的指向 指针也是一种数据类型 指针做函数参数怎么看都不可以 指针也是一个数据类型 是指它指向空间的数据类习惯 作业 野指针 向null空间地址copy数据 不断改变指针指向 …

JVM的组成 -- 字节码文件

类加载器(ClassLoader)&#xff1a;将字节码文件加载到内存中运行时数据区(JVM管理的内存)&#xff1a;负责管理JVM使用的内存&#xff0c;比如创建对象和销毁对象执行引擎&#xff1a;即时编译器、解释器、垃圾回收器。负责本地接口的调用本地接口&#xff1a;native方法&…

高等数学 第八讲 积分学计算_不定积分_定积分_反常积分的计算

高等数学 第八讲 积分学计算 文章目录 高等数学 第八讲 积分学计算1.不定积分的计算1.1 基本积分公式1.2 不定积分的计算方法1.2.1 凑微分法1.2.2 换元法1.2.3 分布积分法1.2.4 有理函数的积分计算(待更新)1.2.5 不定积分的一些计算结论总结 2.定积分的计算2.1 牛顿莱布尼茨公式…