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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 使用云盘创建有状态服务时往往有一个痛点:开始申请云盘的时候不能准确估计服务能用多大存储空间,申请的云盘在服务运行一段时间后空间不够使用!!

介绍

使用云盘创建有状态服务时往往有一个痛点:开始申请云盘的时候不能准确估计服务能用多大存储空间,申请的云盘在服务运行一段时间后空间不够使用!!

本文介绍容器服务使用云盘时,如果进行磁盘扩容;

建议在扩容数据盘之前手动创建快照,以备份数据。

云盘扩容参考文档:https://help.aliyun.com/document_detail/25452.html

创建服务

参考动态云盘服务创建步骤:

# kubectl create -f dynamic.yaml

# kubectl get pod
NAME                             READY     STATUS    RESTARTS   AGE
nginx-dynamic-69f9bd7b8c-hlkxj   1/1       Running   0          29s

# kubectl get pv
NAME                     CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS    CLAIM              STORAGECLASS                  REASON    AGE
d-2ze8enovtwtk8frhdzn0   20Gi       RWO            Retain           Bound     default/disk-ssd   alicloud-disk-ssd-beijing-b             1m

当前使用一个20G的SSD云盘,在云盘中创建一个临时文件:


# kubectl exec nginx-dynamic-69f9bd7b8c-hlkxj df | grep data
/dev/vdc        20511312   45080  19401272   1% /data

# kubectl exec nginx-dynamic-69f9bd7b8c-hlkxj ls /data
lost+found

# kubectl exec nginx-dynamic-69f9bd7b8c-hlkxj touch /data/disk
# kubectl exec nginx-dynamic-69f9bd7b8c-hlkxj ls /data
disk   lost+found    

扩容云盘

1. 停止服务、卸载云盘

删除deploy应用,云盘会自动卸载:

# kubectl delete deploy nginx-dynamic

到云盘控制台查看云盘:d-2ze8enovtwtk8frhdzn0 处于待挂载状态。如果没有卸载成功,可以在控制台执行卸载。

2. 在控制台进行扩容

在ECS控制台对应的云盘信息行中,点击:更多 -- 磁盘扩容 选项,进行云盘扩容,参考:https://help.aliyun.com/document_detail/25452.html

将云盘的大小从20G扩展到30G,扩容完成即可在控制台看到效果。

3. 扩容文件系统

选择一个节点,在控制台上把云盘到这个节点,并记录其挂载的设备名(例如:/dev/vdd);

执行文件系统扩容:

# e2fsck -f /dev/vdd
# resize2fs /dev/vdd

重新创建服务

重新创建服务:

# kubectl create -f dynamic.yaml

# kubectl get pod
NAME                             READY     STATUS    RESTARTS   AGE
nginx-dynamic-69f9bd7b8c-68kqp   1/1       Running   0          7s

查看云盘大小:

# kubectl exec nginx-dynamic-69f9bd7b8c-68kqp df | grep data
/dev/vdd        30832548   45036  29198264   1% /data

验证数据一致性:

# kubectl exec nginx-dynamic-69f9bd7b8c-68kqp ls /data
disk    lost+found
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
2月前
|
Prometheus Kubernetes 监控
k8s部署针对外部服务器的prometheus服务
通过上述步骤,您不仅成功地在Kubernetes集群内部署了Prometheus,还实现了对集群外服务器的有效监控。理解并实施网络配置是关键,确保监控数据的准确无误传输。随着监控需求的增长,您还可以进一步探索Prometheus生态中的其他组件,如Alertmanager、Grafana等,以构建完整的监控与报警体系。
137 60
|
2月前
|
Prometheus Kubernetes 监控
k8s部署针对外部服务器的prometheus服务
通过上述步骤,您不仅成功地在Kubernetes集群内部署了Prometheus,还实现了对集群外服务器的有效监控。理解并实施网络配置是关键,确保监控数据的准确无误传输。随着监控需求的增长,您还可以进一步探索Prometheus生态中的其他组件,如Alertmanager、Grafana等,以构建完整的监控与报警体系。
270 62
|
1月前
|
存储 Kubernetes 网络协议
k8s的无头服务
Headless Service 是一种特殊的 Kubernetes 服务,其 `spec:clusterIP` 设置为 `None`,不会分配 ClusterIP,通过 DNS 解析提供服务发现。与普通服务不同,Headless Service 不提供负载均衡功能,每个 Pod 都有唯一的 DNS 记录,直接映射到其 IP 地址,适用于有状态应用的场景,如与 StatefulSet 一起部署数据库。示例中通过创建 Nginx 的 StatefulSet 和 Headless Service,展示了如何直接访问单个 Pod 并进行内容修改。
52 3
|
1月前
|
存储 Kubernetes Devops
Kubernetes集群管理和服务部署实战
Kubernetes集群管理和服务部署实战
52 0
|
2月前
|
负载均衡 Kubernetes 区块链
随机密码生成器+阿里k8s负载均衡型服务加证书方法+移动终端设计+ico生成器等
随机密码生成器+阿里k8s负载均衡型服务加证书方法+移动终端设计+ico生成器等
61 1
|
1天前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes Ingress:灵活的集群外部网络访问的利器
《Kubernetes Ingress:集群外部访问的利器-打造灵活的集群网络》介绍了如何通过Ingress实现Kubernetes集群的外部访问。前提条件是已拥有Kubernetes集群并安装了kubectl工具。文章详细讲解了Ingress的基本组成(Ingress Controller和资源对象),选择合适的版本,以及具体的安装步骤,如下载配置文件、部署Nginx Ingress Controller等。此外,还提供了常见问题的解决方案,例如镜像下载失败的应对措施。最后,通过部署示例应用展示了Ingress的实际使用方法。
14 2
|
13天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
1月前
|
Kubernetes 监控 Cloud Native
Kubernetes集群的高可用性与伸缩性实践
Kubernetes集群的高可用性与伸缩性实践
72 1
|
2月前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
2月前
|
Kubernetes 持续交付 开发工具
ACK One GitOps:ApplicationSet UI简化多集群GitOps应用管理
ACK One GitOps新发布了多集群应用控制台,支持管理Argo CD ApplicationSet,提升大规模应用和集群的多集群GitOps应用分发管理体验。

相关产品

  • 容器服务Kubernetes版