在K8S上Redis群

本文介绍了如何在Kubernetes(K8S)上部署Redis集群,重点讨论了由于Redis的有状态特性带来的挑战,如数据持久化和网络标识。通过使用StatefulSet和Headless Service解决这些问题,详细阐述了创建ConfigMap、HeadlessService、StatefulSet的步骤,并展示了初始化Redis集群和创建服务的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题分析

    基本上来说,上部署一个重新部署,但在 k 部署一个普通应用程序并没有什么区别,下面几个问题:

1、REDIS是一个有状态的应用

    这是redis集群时我们最需要注意的问题,当我们把redis以pod的形式部署在k8中的时候,每个pod缓存的数据都不一样,而且pod的IP是会变化的,这什么时候如果使用普通的部署和服务部署来redis-cluster经常出现很多问题,因此需要改用StatefulSet + Headless Service来解决。

2、数据持久化

    redis 虽然是内存的缓存,但需要依赖于磁盘数据进行显示的化,以便服务重启时可能已经恢复了缓存的数据表中,我们需要使用共享文件系统 + PV,在卷)方式来让整个集群中的所有豆荚都可以共享同一层化储存。

概念介绍

    在几个开始之前先来详细介绍一下概念和原理。

1、无头服务

    有句话说,Headless Service 没有指定Cluster 的Service,相应的,k8s 的简单映射在IP 里,Headless Service 的解析结果不是一个Cluster IP,而是它所关联的所有Pod 的IP 列表。

2、有状态集

  StatefulSet是几个地方用于解决应用部署的一种情况,8种情况可以认为这是一种Deployment/RC变化,它有以下特性:

    StatefulSet 管理的每个 Pod 都有唯一的文档/网络标识,按照规律生成,而不是像 Deployment 中的那个名称和 IP 都是经常的。(并且 StatefulSet 的名字是redis,那么pod的名字就是redis-0, redis-1 ...)

    StatefulSet中ReplicaSet的启停顺序是严格受控的,操作第一个pod一定要等前N-1个执行才可以。

    StatefulSet 的 Pod 的稳定化存储,并且采用了不同 Pod 的容量而不会被 PV 保留。

    另外,StatefulSet 要配合每个 Headless Service 使用,它会在 Headless Service 提供的 DNS 传输上,最终准确到 Pod 的域名格式需要说明,格式如下:

$(podname).$(headless service name)

    映射这个,备用集群时使用域名IP,实现有状态应用就可以在配置的管理。

方案

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

倾听铃的声

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值