k8s 资源编排 yaml

简介: 作者主页:https://www.couragesteak.com/

1 yaml介绍

1.1 yaml 文件概述

k8s集群中对资源管理和资源对象编排部署都可以通过声明样式(yaml)文件来解决,也就是可以把需要对资源对象操作编辑到的yaml格式文件中,我们把这种文件叫做资源清单文件,通过kubectl命令直接使用资源清单文件,通过kubectl命令直接使用资源清单文件就可以实现对大量的资源对象进行编排部署了。

1.2 yaml文件书写格式

(1)yaml介绍

  • yaml:仍是一种标记语言。为了强调这种语言以数据作为中心,而不是以标记语言为重点。
  • yaml是一个可读性高,用来表达数据序列的格式。

(2)yaml基本语法

  • 使用空格作为缩进
  • 缩进的空格数据不重要,只要相同层级的元素左侧对齐即可。

1.3 yaml实例

查看k8s版本

kubectl api-versions

查看资源类型

kubectl api-resources
apiVersion: apps/v1  # API版本
kind: Deployment  # 资源类型
metedata:  # 资源元数据
  name:nginx-deployment  
  namespace: default
spec:  # 资源规格
  replicas: 3  # 副本数量
  selector:  # 标签选择器
    matchLabels:
      app: nginx
  template:  # Pod模板
    metadata:  # Pod元数据
      labels:
        app: nginx
    spec:  # Pod规格
      containers:  # 容器配置
      - name: nginx
        image: nginx:latest
        port:
        - containerPort: 80

在这里插入图片描述
apiVersion:API版本
kind:资源类型
metadata:资源元数据
spec:资源规格
replicas:副本数量
selector:标签选择器
template:Pod模板
metadata:Pod元数据
spec:Pod规格
容器配置:容器配置

2 yaml文件快速编写

2.1 kubectl create命令生成

资源未部署,可以使用

1、创建资源 my-nginx

kubectl create deployment my-nginx

2、将创建my-nginx资源过程用yaml生成
基于上一步

kubectl create deployment my-nginx --image=nginx -o yaml

3、尝试运行,但并不真运行
基于上一步

kubectl create deployment my-nginx --image=nginx -o yaml --dry-run

3、生成yaml,并保存到文件
基于上一步

kubectl create deployment my-nginx --image=nginx -o yaml --dry-run > my-nginx.yaml

然后根据实际,修改里面的内容![

2.2 kubectl get命令到处yaml文件

适用于:项目已经部署,对原有yaml修改

查看

kubectl get deploy

在这里插入图片描述
将nginx相关内容,以yaml文件形式导出

kubectl get deploy nginx -o=yaml --export > my-nginx02.yaml

已知:1.20已经不支持:--export ,故直接 > 导出即可

kubectl get deploy nginx -o=yaml --export > my-nginx02.yaml

其他方法:
直接rancher平台,web生成

参考地址:
https://www.bilibili.com/video/BV1GT4y1A756

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
7月前
|
Kubernetes Cloud Native 应用服务中间件
【云原生】使用k8s创建nginx服务—通过yaml文件svc类型暴露
【云原生】使用k8s创建nginx服务—通过yaml文件svc类型暴露
148 0
|
5天前
|
Kubernetes Cloud Native Docker
云原生|kubernetes|网络插件flannel二进制部署和calico的yaml清单部署总结版
云原生|kubernetes|网络插件flannel二进制部署和calico的yaml清单部署总结版
161 0
|
7月前
|
Kubernetes 应用服务中间件 nginx
kubernetes集群命令行工具kubectl介绍&yaml文件介绍-20230208
kubernetes集群命令行工具kubectl介绍&yaml文件介绍-20230208
|
5天前
|
JSON Kubernetes Go
IDEA使用Kubernetes插件编写YAML
IDEA使用Kubernetes插件编写YAML
44 0
IDEA使用Kubernetes插件编写YAML
|
7月前
|
Kubernetes Java 容器
k8s部署springboot项目yaml
k8s部署springboot项目yaml
133 0
|
7月前
|
Kubernetes NoSQL 关系型数据库
通过编写k8s的资源清单yaml文件部署gitlab服务
通过编写k8s的资源清单yaml文件部署gitlab服务
|
5天前
|
JSON Kubernetes API
k8s学习-k8s资源对象与yaml结构
k8s学习-k8s资源对象与yaml结构
55 0
|
5月前
|
存储 Kubernetes Perl
k8s(10)声明式对象配置--yaml文件
k8s(10)声明式对象配置--yaml文件
61 0
|
9月前
|
Kubernetes 应用服务中间件 调度
Kubernetes 中几种常见的调度方式以及对应的 YAML 示例
在 Kubernetes 中,使用 YAML 文件来定义和配置 Pod。以下是几种常见的调度方式以及对应的 YAML 示例: 1. 基于资源需求与节点容量的调度: ```yaml apiVersion: v1 kind: Pod metadata: name: my-pod spec: containers: - name: my-container image: nginx resources: requests: cpu: "0.5" memory: "512Mi" limits: cpu
|
12月前
|
运维 Kubernetes Cloud Native

推荐镜像

更多