1. 前言
本文中,我们会基于sealos制作一个Redis集群镜像。
使用这个集群镜像,我们能够在sealos拉起的K8S集群中,一键部署单节点Redis7.0.7。
参考文档:
2. 前置条件
安装sealos4.2.0,拉起K8S 1.24.8集群(同时安装helm),具体方法参考《sealos入门篇》。
3. 制作Redis集群镜像
1、添加chart仓库
1 | helm repo add bitnami https://charts.bitnami.com/bitnami |
2、下载chart
1 | mkdir redis && cd redis |
这里下载 chart17.4.1 版本,对应 redis7.0.7 版本。
下载的文件名为:redis-17.4.1.tgz
3、修改chart
1 | tar -xzvf redis-17.4.1.tgz |
修改chart的values.yaml,给一些默认值,然后重新打包chart,后续Dockerfile中的CMD中可以少填一些参数。
如下修改:
- global.storageClass 不变,使用默认的storageclass即可
- global.redis.password 修改redis密码 redis123
- auth.password 修改redis密码 redis123
- architecture 单机模式修改为standalone
- master.persistence.size 修改为期望的存储大小 200Gi
- master.service.type 修改为NodePort
- master.resources.requests 按需修改,推荐1C4Gi
- master.resources.limits 按需修改,推荐2C8Gi
- commonConfiguration 按需修改,对应 redis.conf 配置文件内容
3、添加镜像列表
1 | mkdir -p images/shim/ |
内容为:
1 | docker.io/bitnami/redis:7.0.7-debian-11-r7 |
4、编写Dockerfile
1 | FROM scratch |
5、构建集群镜像
1 | sealos build -f Dockerfile -t docker.io/voidking/redis:v7.0.7 . |
4. 使用redis集群镜像
4.1. 自定义安装redis
1 | sealos run docker.io/voidking/redis:v7.0.7 --cmd="helm install redis redis-17.4.1-custom.tgz \ |
4.2. 上传集群镜像
上传到公共镜像仓库
1 | sealos push docker.io/voidking/redis:v7.0.7 |
上传到私有镜像仓库
1 | sealos tag docker.io/voidking/redis:v7.0.7 harbor.voidking.com/sealos/redis:v7.0.7 |
4.3. 卸载redis
1 | helm list -A |
4.4. 删除历史镜像
1 | sealos images | grep '<none>' | awk '{print $3}' | xargs sealos rmi |