K8s使用ConfigMap配置Redis

网友投稿 292 2022-09-08

K8s使用ConfigMap配置Redis

按照下面的步骤,使用 ConfigMap 中的数据来配置 Redis 缓存。 首先创建一个配置模块为空的 ConfigMap:

cat <./example-redis-config.yamlapiVersion: v1kind: ConfigMapmetadata: name: example-redis-configdata: redis-config: ""

应用上面创建的 ConfigMap 以及 Redis pod 清单:

kubectl apply -f example-redis-config.yamlkubectl apply -f Redis pod 清单的内容,并注意以下几点:

由 spec.volumes[1] 创建一个名为 config 的卷。spec.volumes[1].items[0] 下的 key 和 path 会将来自 example-redis-config ConfigMap 中的 redis-config 密钥公开在 config 卷上一个名为 redis-config 的文件中。然后 config 卷被 spec.containers[0].volumeMounts[1] 挂载在 /redis-master。这样做的最终效果是将上面 example-redis-config 配置中 data.redis-config 的数据作为 Pod 中的 /redis-master/redis.conf 公开。

apiVersion: v1kind: Podmetadata: name: redisspec: containers: - name: redis image: redis:5.0.4 command: - redis-server - "/redis-master/redis.conf" env: - name: MASTER value: "true" ports: - containerPort: 6379 resources: limits: cpu: "0.1" volumeMounts: - mountPath: /redis-master-data name: data - mountPath: /redis-master name: config volumes: - name: data emptyDir: {} - name: config configMap: name: example-redis-config items: - key: redis-config path:

检查创建的对象:kubectl get pod/redis configmap/example-redis-config 你应该可以看到以下输出:

NAME READY STATUS RESTARTS AGEpod/redis 1/1 Running 0 8sNAME DATA AGEconfigmap/example-redis-config 1 14s

回顾一下,我们在 example-redis-config ConfigMap 保留了空的 redis-config 键:kubectl describe configmap/example-redis-config 你应该可以看到一个空的 redis-config 键:

Name: example-redis-configNamespace: defaultLabels: Annotations: Data====

使用 kubectl exec 进入 pod,运行 redis-cli 工具检查当前配置:kubectl exec -it redis – redis-cli 查看 maxmemory:

127.0.0.1:6379> CONFIG GET maxmemory 它应该显示默认值 0:

1) "maxmemory"2) "0"

同样,查看 maxmemory-policy:

127.0.0.1:6379>

它也应该显示默认值 noeviction:

1) "maxmemory-policy"2) "noeviction"

现在,向 example-redis-config ConfigMap 添加一些配置:

apiVersion: v1kind: ConfigMapmetadata: name: example-redis-configdata: redis-config: | maxmemory 2mb maxmemory-policy allkeys-lru

应用更新的 ConfigMap:kubectl apply -f example-redis-config.yaml 确认 ConfigMap 已更新:kubectl describe configmap/example-redis-config 你应该可以看到我们刚刚添加的配置:

Name: example-redis-configNamespace: defaultLabels: Annotations: Data====

通过 kubectl exec 使用 redis-cli 再次检查 Redis Pod,查看是否已应用配置:kubectl exec -it redis – redis-cli 查看 maxmemory:

127.0.0.1:6379>

它保持默认值 0:

1) "maxmemory"2) "0"

同样,maxmemory-policy 保留为默认设置 noeviction: 127.0.0.1:6379> CONFIG GET maxmemory-policy 返回:

1) "maxmemory-policy"2) "noeviction"

配置值未更改,因为需要重新启动 Pod 才能从关联的 ConfigMap 中获取更新的值。 让我们删除并重新创建 Pod: kubectl delete pod redis kubectl apply -f 现在,最后一次重新检查配置值:kubectl exec -it redis – redis-cli 查看 maxmemory: 127.0.0.1:6379> CONFIG GET maxmemory 现在,它应该返回更新后的值 2097152:

1) "maxmemory"2) "2097152"

同样,maxmemory-policy 也已更新:

127.0.0.1:6379> CONFIG GET maxmemory-policy 现在它反映了期望值 allkeys-lru:

1) "maxmemory-policy"2) "allkeys-lru"

删除创建的资源,清理你的工作:kubectl delete pod/redis configmap/example-redis-config

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:K8s资源及其在API中的组织形式
下一篇:执着于真玩家,《梦幻西游》电脑版代言人营销图的是什么?
相关文章

 发表评论

暂时没有评论,来抢沙发吧~