K8S有状态服务-静态云盘使用最佳实践

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 云盘为阿里云存储团队提供的非共享存储,只能同时被一个 pod 挂载。集群中只有与云盘在同一个可用区(Zone)的节点才可以挂载云盘。

Kubernetes最新的版本对有状态服务做了较多的增强,包括添加了CSI Plugin、Local Volume、PVC保护、Volume Resize等。本系列文章着重介绍K8S有状态服务的各种应用实践,并结合阿里云存储系列产品底座,为您使用K8S有状态服务拓展业务提供参考。

K8S有状态服务-静态云盘使用最佳实践

K8S有状态服务-动态云盘使用最佳实践

K8S有状态服务-共享存储使用最佳实践

K8S有状态服务-StatefulSet使用最佳实践

K8S有状态服务-云盘扩容解决方案

K8S有状态服务-LocalVolume使用最佳实践

介绍

云盘为阿里云存储团队提供的非共享存储,只能同时被一个 pod 挂载。集群中只有与云盘在同一个可用区(Zone)的节点才可以挂载云盘。

使用场景

某些对磁盘IO要求高的应用,且没有共享数据的需求,如Mysql、Redis等数据存储服务;
高速写日志的场景;
对存储数据需要持久化,不会因pod挂掉而消失;

两种使用云盘方案

静态方式:

手动创建PV、PVC资源对象;
这种方式适合于已经购买了云盘实例的情况下;

动态方式:

手动创建PVC,在PVC中声明StorageClass;
通过storageclass自动创建PV资源对象;
这种方式适合于没有购买云盘,在应用部署时自动购买的情况;

创建云盘PV

创建PV前要确保在ECS控制台创建了待用云盘,并获取云盘ID;

PV名字需要和云盘ID保持一致,如下:

apiVersion: v1
kind: PersistentVolume
metadata:
  name: d-bp1j17ifxfasvts3tf40
  labels:
    alicloud-pvname: d-bp1j17ifxfasvts3tf40
    failure-domain.beta.kubernetes.io/zone: cn-hangzhou-b
    failure-domain.beta.kubernetes.io/region: cn-hangzhou
spec:
  capacity:
    storage: 20Gi
  accessModes:
    - ReadWriteOnce
  flexVolume:
    driver: "alicloud/disk"
    fsType: "ext4"
    options:
      volumeId: "d-bp1j17ifxfasvts3tf40"

其中,zone、region两个labels在多个zone环境下是必须的,此label会保证pod调度到云盘所在的zone;

failure-domain.beta.kubernetes.io/zone: cn-hangzhou-b
failure-domain.beta.kubernetes.io/region: cn-hangzhou

alicloud-pvname为一个标签,标明唯一pv,可以为pvc筛选pv配置中使用;

alicloud-pvname: d-bp1j17ifxfasvts3tf40

使用云盘卷创建应用

创建云盘存储声明PVC,使用selector进行pv筛选,这样可以精确配置PVC、PV的绑定关系;

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: pvc-disk
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 20Gi
  selector:
    matchLabels:
      alicloud-pvname: d-bp1j17ifxfasvts3tf40
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-static
  labels:
    app: nginx
spec:
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx
        volumeMounts:
          - name: disk-pvc
            mountPath: "/data"
      volumes:
        - name: disk-pvc
          persistentVolumeClaim:
            claimName: pvc-disk

高可用验证

创建应用

# kubectl create -f static.yaml

# kubectl get pod | grep static
nginx-static-85f99b4448-clnb2   1/1       Running   0          1m

# kubectl exec nginx-static-85f99b4448-clnb2 df | grep data
/dev/vdc        20511312   45080  19401272   1% /data

在云盘中创建文件:

# kubectl exec nginx-static-85f99b4448-clnb2 ls /data
lost+found

# kubectl exec nginx-static-85f99b4448-clnb2 touch /data/hello

# kubectl exec nginx-static-85f99b4448-clnb2 ls /data
hello
lost+found

删除Pod,验证文件持久化:

# kubectl delete pod nginx-static-85f99b4448-clnb2
pod "nginx-static-85f99b4448-clnb2" deleted

# kubectl get pod
NAME                            READY     STATUS              RESTARTS   AGE
nginx-static-85f99b4448-clnb2   0/1       Terminating         0          4m
nginx-static-85f99b4448-x5b28   0/1       ContainerCreating   0          4s

# kubectl exec nginx-static-85f99b4448-x5b28 ls /data
hello
lost+found
相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
3月前
|
Prometheus 监控 Kubernetes
如何用 Prometheus Operator 监控 K8s 集群外服务?
如何用 Prometheus Operator 监控 K8s 集群外服务?
|
1月前
|
Kubernetes 应用服务中间件 nginx
K8S部署Metrics-Server服务
K8S部署Metrics-Server服务
22 1
|
2月前
|
运维 Kubernetes 持续交付
构建高效自动化运维体系:基于Docker和Kubernetes的最佳实践
在现代云计算环境中,自动化运维成为保障系统稳定性与提升效率的关键。本文深入探讨了如何利用Docker容器化技术和Kubernetes容器编排工具构建一个高效、可靠的自动化运维体系。文中不仅介绍了相关的技术原理,还结合具体案例分析了实施过程中的常见问题及解决方案,为读者提供了一套行之有效的最佳实践指南。
|
2月前
|
人工智能 监控 Serverless
如何基于ACK Serverless快速部署AI推理服务
通过上述步骤,可以在ACK Serverless上快速部署AI推理服务,实现高可用、弹性扩展的服务架构。
22 1
|
2月前
|
Kubernetes 应用服务中间件 nginx
K8S(05)核心插件-ingress(服务暴露)控制器-traefik
K8S(05)核心插件-ingress(服务暴露)控制器-traefik
33 0
|
2月前
|
Kubernetes 网络协议 Docker
K8S核心插件-coredns服务
K8S核心插件-coredns服务
16 0
|
2月前
|
Kubernetes 应用服务中间件 nginx
Kubernetes服务网络Ingress网络模型分析、安装和高级用法
Kubernetes服务网络Ingress网络模型分析、安装和高级用法
44 5
|
3月前
|
Kubernetes 关系型数据库 MySQL
K8S客户端二 使用Rancher部署服务
使用rancher服务操作步骤
|
9天前
|
运维 Kubernetes 监控
Kubernetes 集群的持续性能优化实践
【4月更文挑战第26天】 在动态且不断增长的云计算环境中,维护高性能的 Kubernetes 集群是一个挑战。本文将探讨一系列实用的策略和工具,旨在帮助运维专家监控、分析和优化 Kubernetes 集群的性能。我们将讨论资源分配的最佳实践,包括 CPU 和内存管理,以及集群规模调整的策略。此外,文中还将介绍延迟和吞吐量的重要性,并提供日志和监控工具的使用技巧,以实现持续改进的目标。
|
1天前
|
运维 监控 Kubernetes
Kubernetes 集群的监控与维护策略
【5月更文挑战第4天】 在当今微服务架构盛行的时代,容器化技术已成为软件开发和部署的标准实践。Kubernetes 作为一个开源的容器编排平台,因其强大的功能和灵活性而广受欢迎。然而,随着 Kubernetes 集群规模的扩大,集群的监控和维护变得日益复杂。本文将探讨 Kubernetes 集群监控的重要性,分析常见的监控工具,并提出一套有效的集群维护策略,以帮助运维人员确保集群的健康运行和高可用性。
16 10

相关产品

  • 容器服务Kubernetes版
  • 推荐镜像

    更多