精通Kubernetes:利用YAML轻松管理资源

简介: 精通Kubernetes:利用YAML轻松管理资源

YAML(另一种标记语言)是一种人类可读的数据序列化格式,通常用于不同系统之间的配置文件和数据交换。与 XML 或 JSON 等其他格式相比,它因其简单性和易用性而广受欢迎


Kubernetes[1] 是流行的开源容器编排系统,它使用 YAML 定义其配置文件(称为清单)。这些清单用于定义和Deployment Pod、服务和Deployment配置等资源。


为什么 YAML 如此受欢迎?


YAML 的简单性和易用性使其成为 Kubernetes 配置的流行选择,因为它允许开发人员快速轻松地定义和Deployment他们的应用程序。此外,YAML 的层次结构使阅读和理解复杂的配置变得容易。


YAML 对于 Kubernetes 很重要,因为它提供了一种简单的、人类可读的格式来定义和Deployment复杂的配置,使开发人员更容易使用系统。


以下是 10 个最重要的 Kubernetes YAML 技巧和示例:


1.使用命名空间来隔离资源


命名空间允许你对资源进行逻辑分组并管理应用程序不同部分的访问控制。例如,你可以为开发、测试和生产环境创建命名空间:


apiVersion: v1
kind: Namespace
metadata:
  name: development


2.使用标签和选择器进行资源管理:


标签和选择器使你可以根据特定条件轻松组织和选择资源。例如,你可以使用应用程序名称标记Deployment,并使用选择器查找属于该Deployment的所有 Pod:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  labels:
    app: nginx
spec:
  selector:
    matchLabels:
      app: nginx


3.使用ConfigMaps和Secrets进行配置管理


ConfigMaps 和 Secrets 允许你独立于容器和 Pod 管理配置数据。例如,你可以将环境变量存储在 ConfigMap 中:

apiVersion: v1
kind: ConfigMap
metadata:
  name: env-config
data:
  ENV_VAR_1: "value1"
  ENV_VAR_2: "value2"


4. 使用资源限制和请求进行 Pod 和容器资源管理


资源限制和请求允许你指定 Pod 和容器所需的资源量。例如,你可以指定容器的 CPU 和内存限制:

apiVersion: v1
kind: Pod
metadata:
  name: mypod
spec:
  containers:
  - name: mycontainer
    image: myimage
    resources:
      limits:
        memory: "64Mi"
        cpu: "500m"
      requests:
        memory: "32Mi"
        cpu: "250m"


5. 使用 InitContainers 进行预配置任务


InitContainers 允许你在主容器启动之前运行任务。例如,你可以在主容器启动之前使用 InitContainer 安装软件包:

apiVersion: v1
kind: Pod
metadata:
  name: mypod
spec:
  initContainers:
  - name: init-container
    image: busybox
    command: ["/bin/sh", "-c", "apt-get update && apt-get install -y mypackage"]
  containers:
  - name: mycontainer
    image: myimage


6. 使用 Readiness 和 Liveness 探针进行容器健康检查


就绪性和存活性探针允许你检查容器的运行状况并确保它们已准备好为流量提供服务。例如,你可以使用存活性探针来确保容器正确运行:


apiVersion: v1
kind: Pod
metadata:
  name: mypod
spec:
  containers:
  - name: mycontainer
    image: myimage
    livenessProbe:
      httpGet:
        path: /healthz
        port: 8080
      initialDelaySeconds: 15
      periodSeconds: 5


7. 使用Deployment滚动更新部署


RollingUpdate允许你管理Deployment的更改并确保使用滚动更新来逐步Deployment更改:


apiVersion: apps/v1
kind: Deployment
metadata:
  name: example-deployment
spec:
  replicas: 3
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxSurge: 1
      maxUnavailable: 0
  selector:
    matchLabels:
      app: example-app
  template:


8. 使用 YAML 注释使你的文件更具可读性:


# This is a comment in a YAML file
apiVersion: v1
kind: Pod
metadata:
  name: example-pod
  labels:
    app: example-app


9.使用锚点和锚点别名以避免重复代码


# Anchor definition
anchors:
  pod_template: &pod_template
    apiVersion: v1
    kind: Pod
    metadata:
      labels:
        app: example-app
# Aliased resource definition
apiVersion: v1
kind: Pod
metadata:
  name: example-pod1
  <<: *pod_template
apiVersion: v1
kind: Pod
metadata:
  name: example-pod2
  <<: *pod_template


10.在YAML文件中使用环境变量而不是硬编码值


apiVersion: v1
kind: Pod
metadata:
  name: example-pod
spec:
  containers:
  - name: example-container
    image: example-image
    env:
    - name: EXAMPLE_VAR
      value: example-value


11.使用ConfigMaps和Secrets来存储敏感信息:


apiVersion: v1
kind: ConfigMap
metadata:
  name: example-configmap
data:
  key: value
apiVersion: v1
kind: Secret
metadata:
  name: example-secret
stringData:
  username: user
  password: pass

总结


本文介绍了 YAML(Yet Another Markup Language)在 DevOps 和容器编排社区中的流行程度,特别是在使用 Kubernetes、Ansible 和 Docker 等工具的开发人员和组织中。它是一种人类可读的数据序列化格式,常用于配置文件和不同系统之间的数据交换。


在 Kubernetes 中,YAML 用于定义配置文件,包括命名空间跟李、标签和选择器资源管理、ConfigMaps 和 Secrets 配置管理、资源限制和请求、InitContainers 预配置任务、以及容器健康检查等方面。 这种简单易用的格式使得开发人员能够快速定义和部署他们的应用程序,为复杂配置提供了清晰易懂的表示方式,对于 Kubernetes 的重要性也得到了强调。


引用链接


[1] Kubernetes: https://kubetools.collabnix.com/

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
7月前
|
存储 Kubernetes 对象存储
部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
借助阿里云ACK One注册集群,充分利用阿里云强大ACS GPU算力,实现DeepSeek推理模型高效部署。
|
12月前
|
JSON Kubernetes API
深入理解Kubernetes配置:编写高效的YAML文件
深入理解Kubernetes配置:编写高效的YAML文件
|
7月前
|
存储 Kubernetes 对象存储
部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
部署DeepSeek但GPU不足,ACK One注册集群助力解决IDC GPU资源不足
160 3
|
7月前
|
弹性计算 运维 Kubernetes
使用ACK Edge统一管理多地域的ECS资源
使用ACK Edge统一管理多地域的ECS资源
|
7月前
|
存储 Kubernetes 对象存储
部署 DeepSeek 但 GPU 不足,ACK One 注册集群助力解决 IDC GPU 资源不足
部署 DeepSeek 但 GPU 不足,ACK One 注册集群助力解决 IDC GPU 资源不足
|
8月前
|
弹性计算 运维 Kubernetes
使用ACK Edge统一管理多地域的ECS资源
本文介绍如何使用ACK Edge来管理分布在多个地域的ECS资源。
|
11月前
|
JSON 运维 Kubernetes
|
11月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
181 2
k8s学习--YAML资源清单文件托管服务nginx
|
11月前
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
281 3
|
11月前
|
Kubernetes Docker Perl
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
k8s常见故障--yaml文件检查没有问题 pod起不来(一直处于创建中)
320 1

推荐镜像

更多